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;

    }
};

今日总结

相关推荐
Sheep Shaun12 分钟前
深入理解红黑树:从概念到完整C++实现详解
java·开发语言·数据结构·c++·b树·算法
Dave.B13 分钟前
:vtkBooleanOperationPolyDataFilter 布尔运算全解析
算法·vtk
易晨 微盛·企微管家18 分钟前
2025企业微信AI智能机器人实战指南:3步实现客服自动化
大数据·人工智能·算法
jiaguangqingpanda19 分钟前
Day26-20260122
java·算法·排序算法
踩坑记录24 分钟前
leetcode hot100 160.相交链表 easy 链表双指针
leetcode
secondyoung25 分钟前
队列原理与实现全解析
c语言·数据库·mysql·算法·队列
kuiini26 分钟前
scikit-learn 常用算法与评估方法【Plan 7】
python·算法·scikit-learn
旭意29 分钟前
数据结构-红黑树和set
数据结构·c++·算法·蓝桥杯
宵时待雨29 分钟前
数据结构(初阶)笔记归纳7:链表OJ
c语言·开发语言·数据结构·笔记·算法·链表
充值修改昵称30 分钟前
数据结构基础:堆高效数据结构全面解析
数据结构·python·算法