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 小时前
【算法】四大基础数据结构
数据结构·算法
老一岁3 小时前
希尔排序详解
数据结构·算法·排序算法
lifallen3 小时前
KafkaStreams 计算图节点设计:ProcessorNode、SourceNode、SinkNode
java·数据结构·算法·kafka·apache
索迪迈科技3 小时前
java后端工程师进修ing(研一版‖day42)
java·开发语言·学习·算法
名誉寒冰3 小时前
LeetCode 24 两两交换链表中的节点( 迭代与递归)
算法·leetcode·链表
小欣加油3 小时前
leetcode LCR 170.交易逆序对的总数
数据结构·c++·算法·leetcode·职场和发展·排序算法
kyle~3 小时前
排序---希尔排序(Shell Sort)
数据结构·算法·排序算法
lxh01133 小时前
数组中的第K个最大元素
数据结构·算法
木尼1234 小时前
leedcode 算法刷题第三十一天
算法·leetcode·职场和发展