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;

    }
};

今日总结

相关推荐
努力学算法的蒟蒻3 分钟前
day14(11.14)——leetcode面试经典150
算法·leetcode
让我们一起加油好吗21 分钟前
【数据结构】并查集(操作详解 + 模板 + 练习)
数据结构·算法·并查集·洛谷
PenguinLeee25 分钟前
KKT条件:对偶问题、KKT条件以及内点法
算法·凸优化
Blossom.1181 小时前
大模型知识蒸馏实战:从Qwen-72B到Qwen-7B的压缩艺术
大数据·人工智能·python·深度学习·算法·机器学习·pygame
yoke菜籽2 小时前
面试150——二叉树
面试·职场和发展
海琴烟Sunshine4 小时前
leetcode 383. 赎金信 python
python·算法·leetcode
cynicme10 小时前
力扣3228——将 1 移动到末尾的最大操作次数
算法·leetcode
熬了夜的程序员10 小时前
【LeetCode】109. 有序链表转换二叉搜索树
数据结构·算法·leetcode·链表·职场和发展·深度优先
随意起个昵称10 小时前
【递归】二进制字符串中的第K位
c++·算法
测试老哥11 小时前
软件测试之单元测试知识总结
自动化测试·软件测试·python·测试工具·职场和发展·单元测试·测试用例