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

做网站一般多少一元友情链接平台

做网站一般多少,一元友情链接平台,珠海网站建设网络公司怎么样,广东省医院建设协会网站题目 一个文件目录的数据格式为:目录id,本目录中文件大小,(子目录id列表)。其中目录id全局唯一, 取值范围[1 ,200],本目录中文件大小范围[1,1000],子目录id列表个数[0,10] 例如: 1 20 (2,3)表示目录1中文件总大小是20,有两个子目录…

题目

一个文件目录的数据格式为:目录id,本目录中文件大小,(子目录id列表)。其中目录id全局唯一, 取值范围[1 ,200],本目录中文件大小范围[1,1000],子目录id列表个数[0,10]
例如: 1 20 (2,3)表示目录1中文件总大小是20,有两个子目录,id分别是2和3
现在输入一个文件系统中所有目录信息,以及待查询的目录id,返回这个目录和及该目录所有子目录的大小之和
输入描述
第一行为两个数字M,N,分别表示目录的个数和待查询的目录id.
1≤M≤100
1≤N≤200
接下来M行,每行为1个目录的数据
目录id 本目录中文件大小(子目录id列表)
子目录列表中的子目录id以逗号分隔
输出描述
待查询目录及其子目录的大小之和
示例1:
输入
3 1
3 15 (0)
1 20 (2)
2 10 (3)
输出
45
说明
目录1大小为20,包含一个子目录2(大小为10),子目录2包含一个子目录3(大小为15),总的大小为20+ 10+15=45
示例2:
输入
4 2
4 20 ()
5 30 ()
2 10 (4,5)
1 40()
输出
60
说明
目录2包含2个子目录4和5,总的大小为10+20+30= 60

思路

使用两个map分别【存储id-本目录大小】,【id-子目录列表】,假设分别定义为:Map<Integer, Integer> sizeMap ,Map<Integer, int[]> subDirMap
方案一:dfs遍历即可,设计函数dfs(n),n代表待查询目录id

记录当前目录大小:res=sizeMap.get(n)
定义dfs的终止条件:如果子目录为空,终止递归,直接返回res
否则,遍历子目录list,使用res累加上dfs(s),s代表每次遍历的子目录id
最后返回res即可

方案二:利用对列实现

初始对列deque加入待查询目录id:deque.add(n);
遍历deque,如果deque不为空,那么弹出对列,得到目录id:id=deque.pollFirst();
根据id在sizeMap 中找到当前目录的大小,res+=sizeMap.get(id);
根据id在subDirMap中找到当前目录的子目录列表,将子目录列表加入到deque中
遍历完成后,将res返回即可

题解

package hwod;import java.util.*;
import java.util.stream.Collectors;public class DirectorySize {public static void main(String[] args) {Scanner sc = new Scanner(System.in);int m = sc.nextInt();int n = sc.nextInt();sc.nextLine();String[] directoryInfos = new String[m];for (int i = 0; i < m; i++) {directoryInfos[i] = sc.nextLine();}System.out.println(getDirectorySize(directoryInfos, n));}private static Map<Integer, Integer> sizeMap = new HashMap<>();private static Map<Integer, int[]> subDirMap = new HashMap<>();private static int getDirectorySize(String[] infos, int n) {for (int i = 0; i < infos.length; i++) {String[] lines = infos[i].split(" ");int id = Integer.parseInt(lines[0]);int size = Integer.parseInt(lines[1]);sizeMap.put(id, size);String subDirsStr = lines[2].substring(1, lines[2].length() - 1);if ("".equals(subDirsStr)) {subDirMap.put(id, new int[0]);} else {subDirMap.put(id, Arrays.stream(subDirsStr.split(",")).mapToInt(Integer::parseInt).toArray());}}if (!sizeMap.containsKey(n)) return -1;//        return dfs(n);return getForQueue(n);}//方案一:private static int dfs(int n) {int[] subdirs = subDirMap.get(n);int res = sizeMap.get(n);if (subdirs.length == 0) return res;for (int i = 0; i < subdirs.length; i++) {if(!sizeMap.containsKey(subdirs[i])) continue; //兼容错误数据,如:(0,2),(-1,2,999)res += dfs(subdirs[i]);}return res;}//方案二:对列实现private static int getForQueue(int n) {LinkedList<Integer> deque = new LinkedList<>();deque.add(n);int res = 0;while (!deque.isEmpty()) {int id = deque.pollFirst();if(id==0) continue; //如果修改为break,那么子目录不允许这种情况(0,2),(-1,2,999)存在res += sizeMap.get(id);deque.addAll(Arrays.stream(subDirMap.get(id)).boxed().collect(Collectors.toList()));}return res;}}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

http://www.yayakq.cn/news/512619/

相关文章:

  • 制作网站学什么专业马云先做那个网站的起家的
  • 网站建设 微信小程序asp与sql做网站
  • 网站整站网页设计与制作教程期末考试题
  • 济南网站建设公司川芎网络wordpress 文章 attachment_id
  • 浙江华临建设集团有限公司网站wordpress 改为中文字体
  • 网站投稿系统怎么做网站开发junke100
  • 啥是东莞网站制作公司天健emp软件开发平台
  • 来宾网站优化百度影音在线电影
  • 国外优秀flash网站微信如何做模板下载网站
  • 静态网站可以做哪些福州网站建设服务商
  • dw个人网站制作模板北京住房和城乡建设局门户网站
  • 网站抽奖模块怎么做打扑克观看区免费观看
  • PHP手机网站开发工程师山东企业网站建设报价
  • vs做网站怎样添加图片图书馆网站建设总结
  • 注册公司去哪个网站韩国网站怎么打开
  • 东莞 网站制作行业资讯平台网站建设
  • seo教程网站优化做挂网站
  • 网站建设公司 倒闭江宁网站建设公司
  • 平台网站开发方案云主机服务器
  • 北京南昌企业网站制作wordpress 网站搭建
  • 重庆网站平台海南网站搭建
  • 武功做网站济南企业建站哪家做的好
  • 网站优化建设郑州网站搬家seo
  • 专业模板网站制作价格域名服务网站建设科技公司
  • 平顶山网站建设专业建站的网站
  • 有哪些网站是拐角型温州网站建设报价
  • 最具价值的网站建设做企业网站对企业的好处
  • 做网站需要编程基础wordpress视频列表模板
  • 图书销售网站网页设计模板电商app开发方案
  • 能查个人信息的网站南昌公路建设有限公司网站