LeetCode 刷题【71. 简化路径】

71. 简化路径

自己做

解:遍历检查

cpp 复制代码
class Solution {
public:
    string simplifyPath(string path) {
        int p = 0;
        string res;

        while(p < (int)path.size()){
            //情况1:遇到"/./" =》p跳过"/."
            if(p < (int)path.size() - 2 && path[p] == '/' && path[p + 1] == '.' && path[p + 2] == '/')
                p += 2;

            //情况2:遇到"//" =》p跳过"/"
            else if(p < (int)path.size() - 1 && path[p] == '/' && path[p + 1] == '/')
                p++;        

            //情况3_1:遇到"/abc" =》正常输入
            else if(p < (int)path.size() - 1 && path[p] == '/' && path[p + 1] != '/' && path[p + 1] != '.'){
                res.push_back(path[p]);             //加入斜杠
                p++;

                while(p < (int)path.size() && path[p] != '/'){      //加入abc ,直到遍历结束或者遇到下个斜杠
                    res.push_back(path[p]);            
                    p++;                    
                }
            }

            //情况3_2:遇到"/..xxxxx" =》正常输入
            else if(p < (int)path.size() - 3 && path[p] == '/' && path[p + 1] == '.' && path[p + 2] == '.' && path[p + 3] != '/'){
                res.push_back(path[p]);             //加入斜杠
                p++;

                while(p < (int)path.size() && path[p] != '/'){      //加入.......... ,直到遍历结束或者遇到下个斜杠
                    res.push_back(path[p]);             
                    p++;                    
                }
            }

            //情况3_3:遇到"/.xxxx" =》正常输入
            else if(p < (int)path.size() - 2 && path[p] == '/' && path[p + 1] == '.' && path[p + 2] != '.' && path[p + 2] != '/'){
                res.push_back(path[p]);             //加入斜杠
                p++;

                while(p < (int)path.size() && path[p] != '/'){      //加入.......... ,直到遍历结束或者遇到下个斜杠
                    res.push_back(path[p]);             
                    p++;                    
                }
            }

            //情况4:遇到"/../"或者"/.."(末尾) =》弹出上级目录,p跳过"/.."【在检查完有没有/...的情况后】
            else if(p < (int)path.size() - 2 && path[p] == '/' && path[p + 1] == '.' && path[p + 2] == '.'){
                p += 3;
                while(res.size() > 0 && res[(int)res.size() - 1] != '/')   //对于res = "xxx/abc",弹出abc这个上级目录,得到结果res = "xxx/"
                    res.pop_back();
                
                if(res.size() >= 1)     //弹出斜杠
                    res.pop_back();
            } 

            //情况5:末尾不成目录"abc/" =》 结束遍历
            else
                break;

        }

        //防止空目录
        if(res.size() == 0)
            res.push_back('/');


        return res;

    }
};

今日总结

相关推荐
野生技术架构师1 小时前
金三银四面试总结篇,汇总 Java 面试突击班后的面试小册
java·面试·职场和发展
_深海凉_1 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
ja哇2 小时前
大厂面试高频八股
java·面试·职场和发展
踩坑记录2 小时前
leetcode hot100 寻找两个正序数组的中位数 hard 二分查找 双指针
leetcode
旖-旎2 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰2 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx2 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer3 小时前
【无标题】
开发语言·c++·算法
AGV算法笔记3 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家4 小时前
数据链路层基础
网络·学习·算法