当前位置: 首页 > news >正文

网站开发及代运营爱网站查询挖掘工具

网站开发及代运营,爱网站查询挖掘工具,优化稳定网站排名,百度关键字排名软件题目链接 Leetcode.1487 保证文件名唯一 Rating : 1697 题目描述 给你一个长度为 n的字符串数组 names。你将会在文件系统中创建 n个文件夹:在第 i 分钟,新建名为 names[i]的文件夹。 由于两个文件 不能 共享相同的文件名,因此如…

题目链接

Leetcode.1487 保证文件名唯一 Rating : 1697

题目描述

给你一个长度为 n````的字符串数组 names。你将会在文件系统中创建 n个文件夹:在第 i 分钟,新建名为 names[i]```的文件夹。

由于两个文件 不能 共享相同的文件名,因此如果新建文件夹使用的文件名已经被占用,系统会以 (k)的形式为新文件夹的文件名添加后缀,其中 k是能保证文件名唯一的 最小正整数

返回长度为 n的字符串数组,其中 ans[i]是创建第 i个文件夹时系统分配给该文件夹的实际名称。

示例 1:

输入:names = [“pes”,“fifa”,“gta”,“pes(2019)”]
输出:[“pes”,“fifa”,“gta”,“pes(2019)”]
解释:文件系统将会这样创建文件名:
“pes” --> 之前未分配,仍为 “pes”
“fifa” --> 之前未分配,仍为 “fifa”
“gta” --> 之前未分配,仍为 “gta”
“pes(2019)” --> 之前未分配,仍为 “pes(2019)”

示例 2:

输入:names = [“gta”,“gta(1)”,“gta”,“avalon”]
输出:[“gta”,“gta(1)”,“gta(2)”,“avalon”]
解释:文件系统将会这样创建文件名:
“gta” --> 之前未分配,仍为 “gta”
“gta(1)” --> 之前未分配,仍为 “gta(1)”
“gta” --> 文件名被占用,系统为该名称添加后缀 (k),由于 “gta(1)” 也被占用,所以 k = 2 。实际创建的文件名为 “gta(2)” 。
“avalon” --> 之前未分配,仍为 “avalon”

示例 3:

输入:names = [“onepiece”,“onepiece(1)”,“onepiece(2)”,“onepiece(3)”,“onepiece”]
输出:[“onepiece”,“onepiece(1)”,“onepiece(2)”,“onepiece(3)”,“onepiece(4)”]
解释:当创建最后一个文件夹时,最小的正有效 k 为 4 ,文件名变为 “onepiece(4)”。

示例 4:

输入:names = [“wano”,“wano”,“wano”,“wano”]
输出:[“wano”,“wano(1)”,“wano(2)”,“wano(3)”]
解释:每次创建文件夹 “wano” 时,只需增加后缀中 k 的值即可。

示例 5:

输入:names = [“kaido”,“kaido(1)”,“kaido”,“kaido(1)”]
输出:[“kaido”,“kaido(1)”,“kaido(2)”,“kaido(1)(1)”]
解释:注意,如果含后缀文件名被占用,那么系统也会按规则在名称后添加新的后缀 (k) 。

提示:

  • 1<=names.length<=5∗1041 <= names.length <= 5 * 10^41<=names.length<=5104
  • 1<=names[i].length<=201 <= names[i].length <= 201<=names[i].length<=20
  • names[i]由小写英文字母、数字和/或圆括号组成。

分析:

我们用一个 哈希表map记录,每一个文件名 对应的 最小后缀 即可。
对于每一个文件名 s

  • 如果map中找不到s,说明 s是唯一的,直接将其记录到答案中即可,更新 map.put( s , 1 )
  • 如果map中存在s,且 t = map.get(s),那么我们需要不断增加 t,直到 map中不包含 s + "(" + t + ")",并且此时 s的最小后缀要更新为新的 t,即 map.put( s , t ),那么此时的 name = s + "(" + t + ")"就是最新的文件名,记录到答案中,更新 map.put( name , 1 )

时间复杂度:O(names.length∗nums[i].length)O(names.length * nums[i].length)O(names.lengthnums[i].length)

C++代码:

class Solution {
public:vector<string> getFolderNames(vector<string>& names) {unordered_map<string,int> cnt;vector<string> ans;for(auto s:names){int t = cnt[s];if(t){while(cnt.count(s + "(" + to_string(t) + ")")) t++;cnt[s] = t;s += "(" + to_string(t) + ")";}cnt[s] = 1;ans.push_back(s);}return ans;}
};

Java代码:

class Solution {public String[] getFolderNames(String[] names) {Map<String, Integer> map = new HashMap<>();int n = names.length;String[] ans = new String[n];for (int i = 0; i < n; ++i) {String s = names[i];if (map.containsKey(s)) {int t = map.get(s);while (map.containsKey(s + "(" + t + ")"))  t++;map.put(s , t);s += "(" + t + ")";}map.put(s, 1);ans[i] = s;}return ans;}
}
http://www.yayakq.cn/news/469620/

相关文章:

  • 东莞公司网站设计网站备案审核
  • 网站的模版要怎么重新做wordpress插件地图标记
  • 帮人注册网站_做app百度云域名没有备案怎么做网站
  • 做暧暖爱视频网站如何看到网站的建设时间
  • 网站敏感词汇系部网站建设研究方案
  • 网站备案要花钱吗京东网站建设步骤
  • 电影网站盗链怎么做wordpress 找不到文件
  • 重庆网站关键词优化推广企业做的网站推广方案的步骤
  • 永久免费的网站空间开发公司如何加强财务管理
  • 建设网站对公司起什么作用是什么网络营销上市公司
  • 成功的网站必须具备的要素南京百度做网站的电话
  • 网站seo方案有没有做海报的网站推荐
  • 中国城市建设网站合肥做微网站
  • 凡科做网站友情链接怎么做北京中邦亚通网站
  • 怎样用自己的pid做搜索网站用ip地址做网站地址有危险
  • 东莞做个网站鸿星尔克网络推广方案
  • 少主网络建站营销型网站展示
  • 昆明网站建设 技术支持windows优化大师是什么
  • 做的比较好的设计公司网站网站如何收录快
  • 花茶网站设计网站备案信息批量查询
  • 做软件需要网站有哪些做网站黑网站赚钱么么
  • 修改wordpress设置方法淄博网站的优化
  • 做网站排名的公司论坛类的网站怎么做
  • 网站的技术方案电脑做网站服务器需要什么
  • 设计外贸商城网站建设WordPress随机句子
  • 企业网站有哪些内容美容院网站源码
  • 竞价托管咨询微竞价厦门专业做优化的公司
  • 小企业网站建设的小知识网站做支付宝接口
  • 网站挂服务器后图片不显示能够做一镜到底的网站
  • dedecms网站的下载wordpress 京东主题