class Solution { public: string simplifyPath(string path) { int len = path.length(); if (len < 2) return "/"; vector<string> spath; int p = -1, q = 0; // seperate the path into parts & simplify it with a stack while (q < len) { while (q < len && path[q] != ‘/‘) q++; if (p + 1 < q) { add_part_to_spath(path.substr(p + 1, q - p - 1), spath); } p = q; q++; } // build the final simplified path string res; for (int i=0; i<spath.size(); i++) { res.push_back(‘/‘); res.append(spath[i]); } if (res.length() == 0) res = "/"; return res; } void add_part_to_spath(string part, vector<string>& spath) { if (part == ".") { // do nothing; } else if (part == "..") { // goto the parent path part if (!spath.empty()) spath.pop_back(); } else { // enter a new part spath.push_back(part); } } };
也可以直接在原有字符串上操作,但还是这样简单明了一些
LeetCode Simplify Path,布布扣,bubuko.com
原文:http://www.cnblogs.com/lailailai/p/3759523.html