simplify-path

https://leetcode.com/problems/simplify-path/

https://leetcode.com/mockinterview/session/result/xjl3d3m/

现在字符串比较,都知道用 equals了,哈哈。不能用==,否则可能有bug。

 

复制代码
package com.company;


import java.util.*;

class Solution {
    public String simplifyPath(String path) {
        Stack<String> stk= new Stack<>();
        String[] strs = path.split("/");
        for (int i=0; i<strs.length; i++) {
            if (strs[i].equals("") || strs[i].equals(".")) {
                continue;
            }
            else if (strs[i].equals("..")) {
                if (!stk.empty()) {
                    stk.pop();
                }
            }
            else {
                stk.push(strs[i]);
            }
        }

        Stack<String> newStk= new Stack<>();
        String tmp;
        while (!stk.empty()) {
            tmp = stk.pop();
            newStk.push(tmp);
        }

        StringBuilder sb = new StringBuilder();
        while (!newStk.empty()) {
            sb.append("/" + newStk.pop());
        }
        String str = sb.toString();
        if (str.equals("")) {
            str = "/";
        }
        return str;
    }
}

public class Main {

    public static void main(String[] args) throws InterruptedException {

        System.out.println("Hello!");
        Solution solution = new Solution();

        // Your Codec object will be instantiated and called as such:
        String path = "/a/./b/../../c/";
        String ret = solution.simplifyPath(path);
        System.out.printf("ret:%s\n", ret);

        System.out.println();

    }

}
复制代码

 

posted @   blcblc  阅读(165)  评论(0编辑  收藏  举报
编辑推荐:
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· AI与.NET技术实操系列(二):开始使用ML.NET
· 记一次.NET内存居高不下排查解决与启示
阅读排行:
· 被坑几百块钱后,我竟然真的恢复了删除的微信聊天记录!
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 园子的第一款AI主题卫衣上架——"HELLO! HOW CAN I ASSIST YOU TODAY
· Docker 太简单,K8s 太复杂?w7panel 让容器管理更轻松!
点击右上角即可分享
微信分享提示