LeetCode71
题目
71. 简化路径
(图片来源网络,侵删)
思路
说实话 最开始没看懂题目什么意思,去看了题解根据“遇到..弹出栈顶元素” 思想写出代码,使用栈来装目录名称,最后所有元素出栈时与文件路径顺序是相反的;因此考虑使用双端队列来实现栈,最后从另一端取出元素,就可以得到与文件路径一致的顺序;
代码
public String simplifyPath(String path) {
Deque stack = new ArrayDeque();
// 按/分割目录所在路径
String[] subString = path.split("/");
for(int i = 0; i
Tips:双端队列yyds 可以用来实现栈、队列。
题目
102. 二叉树的层序遍历
思路
树的广度优先遍历都可以用两个队列+两层循环进行解决;
代码
public List levelOrder(TreeNode root) {
List re = new ArrayList();
// 使用两个队列来实现
if(root == null){
return re;
}
Queue queue = new LinkedList();
queue.add(root);
while(!queue.isEmpty()){
List tempNodeList = new ArrayList();
Queue tempQueue = new LinkedList();
// 遍历其子节点
TreeNode tempNode = queue.poll();
while(tempNode != null){
// 加入这一层节点的值
tempNodeList.add(tempNode.val);
if(tempNode.left != null){
tempQueue.add(tempNode.left);
}
if(tempNode.right != null){
tempQueue.add(tempNode.right);
}
tempNode = queue.poll();
}
// 更新每一层节点的val
re.add(tempNodeList);
queue = tempQueue;
}
return re;
}
免责声明:我们致力于保护作者版权,注重分享,被刊用文章因无法核实真实出处,未能及时与作者取得联系,或有版权异议的,请联系管理员,我们会立即处理! 部分文章是来自自研大数据AI进行生成,内容摘自(百度百科,百度知道,头条百科,中国民法典,刑法,牛津词典,新华词典,汉语词典,国家院校,科普平台)等数据,内容仅供学习参考,不准确地方联系删除处理! 图片声明:本站部分配图来自人工智能系统AI生成,觅知网授权图片,PxHere摄影无版权图库和百度,360,搜狗等多加搜索引擎自动关键词搜索配图,如有侵权的图片,请第一时间联系我们,邮箱:ciyunidc@ciyunshuju.com。本站只作为美观性配图使用,无任何非法侵犯第三方意图,一切解释权归图片著作权方,本站不承担任何责任。如有恶意碰瓷者,必当奉陪到底严惩不贷!
