怎么删除用户文件夹,把用户文件夹删除了怎么办

#头条创作挑战赛#

题目:

你是一位系统管理员,手里有一份文件夹列表 folder,你的任务是要删除该列表中的所有 子文件夹,并以 任意顺序 返回剩下的文件夹。

如果文件夹 folder[i] 位于另一个文件夹 folder[j] 下,那么 folder[i] 就是 folder[j] 的 子文件夹 。

文件夹的「路径」是由一个或多个按以下格式串联形成的字符串:'/' 后跟一个或者多个小写英文字母。

例如,"/leetcode" 和 "/leetcode/problems" 都是有效的路径,而空字符串和 "/" 不是。

示例 1:

输入:folder = ["/a","/a/b","/c/d","/c/d/e","/c/f"]输出:["/a","/c/d","/c/f"]解释:"/a/b/" 是 "/a" 的子文件夹,而 "/c/d/e" 是 "/c/d" 的子文件夹。示例 2:

输入:folder = ["/a","/a/b/c","/a/b/d"]输出:["/a"]解释:文件夹 "/a/b/c" 和 "/a/b/d/" 都会被删除,因为它们都是 "/a" 的子文件夹。示例 3:

输入: folder = ["/a/b/c","/a/b/ca","/a/b/d"]输出: ["/a/b/c","/a/b/ca","/a/b/d"]

提示:

1 <= folder.length <= 4 * 10^42 <= folder[i].length <= 100folder[i] 只包含小写字母和 '/'folder[i] 总是以字符 '/' 起始每个文件夹名都是 唯一 的

java代码:class Solution { public List<String> removeSubfolders(String[] folder) { Arrays.sort(folder, (a, b) -> a.length() – b.length()); List<String> ans = new ArrayList<>(); Node root = new Node(); for (String path : folder) { String[] d = path.split("/"); Node node = root; for (int i = 0; i < d.length; i++) { node = node.computeIfAbsent(d[i], k -> new Node()); if (node.end) { break; } } if (!node.end) { node.end = true; ans.add(path); } } return ans; } class Node extends HashMap<String, Node> { boolean end; }}

本文地址:https://www.cknow.cn/archives/53770

以上内容源自互联网,由百科助手整理汇总,其目的在于收集传播生活技巧,行业技能,本网站不对其真实性、可靠性承担任何法律责任。特此声明!

如发现本站文章存在版权问题,烦请提供版权疑问、侵权链接、联系方式等信息发邮件至candieraddenipc92@gmail.com,我们将及时沟通与处理。