力扣——简化路径

https://leetcode.cn/problems/simplify-path/description/?envType=study-plan-v2&envId=top-interview-150
在这里插入图片描述
思路:将串以/分割,判断字符串是…/./其他,进行入栈和出栈,最后留下的就是结果,拼装一下就好了。

三个要点:

第一:字符串的比较统一拿equals来比

第二:队列的遍历一定要拿while,不要用for,除非一开始就拿个变量存下来长度,不然遍历时候长度在变化

第三:split()函数会让空开的地方分割出来空字符串“”

举个栗子:

String s = " a b  c";
String[] x = s.split(" ");
for(String unit:x)
	System.out.println(unit);

结果是

a
b

c

代码:

class Solution {
   
    public String simplifyPath(String path) {
   
        String[] units = path.split("/");
        String ans="";
        Deque<String> queue = new LinkedList<>();
        for(int i=0;i<units.length;i++){
   
            //System.out.println(units[i]);
            if(units[i].equals("")||units[i].equals(".")) 
                continue;
            else if(units[i].equals("..")&&queue.size()>0)
                queue.removeFirst();
            else if(units[i].equals("..")&&queue.size()==0) 
                continue;
            else
                queue.addFirst(units[i]);  
        }
        //千万别这么写
        // for(int i=0;i<queue.size();i++){
   
        //     if(i>=1)ans+="/";
        //     ans+=queue.peekFirst();
        //     queue.removeFirst();
        // }
        List<String> list = new ArrayList<>();
        while(queue.size()!=0){
   
            list.add(queue.peekFirst());
            queue.removeFirst();
        }
        for(int i=list.size()-1;i>=0;i--){
   
            ans=ans+"/"+list.get(i);
        }
        if(ans.equals("")) 
            ans = "/";
        return ans;
    }
}

PS:LinkedList的API请添加图片描述

相关推荐

  1. -简化路径

    2023-12-06 11:22:04       13 阅读

最近更新

  1. TCP协议是安全的吗?

    2023-12-06 11:22:04       16 阅读
  2. 阿里云服务器执行yum,一直下载docker-ce-stable失败

    2023-12-06 11:22:04       16 阅读
  3. 【Python教程】压缩PDF文件大小

    2023-12-06 11:22:04       15 阅读
  4. 通过文章id递归查询所有评论(xml)

    2023-12-06 11:22:04       18 阅读

热门阅读

  1. QT基础教程(QPalette和QIcon)

    2023-12-06 11:22:04       32 阅读
  2. mysql中的case when then else end用法

    2023-12-06 11:22:04       40 阅读
  3. (C++20) consteval立即函数

    2023-12-06 11:22:04       41 阅读
  4. map 和 flatMap 的区别

    2023-12-06 11:22:04       36 阅读
  5. 麒麟v10 数据盘初始化 gpt分区

    2023-12-06 11:22:04       43 阅读
  6. golang使用sip实现语音通话

    2023-12-06 11:22:04       38 阅读
  7. LightDB - 支持 last_day 函数[mysql兼容]

    2023-12-06 11:22:04       39 阅读
  8. NLP中几个简单的,字符串相似度计算方法

    2023-12-06 11:22:04       33 阅读
  9. AI:大语言模型LLM

    2023-12-06 11:22:04       39 阅读
  10. Pytest 的小例子

    2023-12-06 11:22:04       38 阅读
  11. css基础

    2023-12-06 11:22:04       37 阅读