当前位置: 首页 > wzjs >正文

手机终端网站网站建设与维护兼职

手机终端网站,网站建设与维护兼职,中山商城网站建设,找人做网站 自己购买服务器给你一个字符串path,表示指向某一文件或目录的Unix风格 绝对路径(以‘/’开头),请你将其转化为更加简洁的规范路径。 在Unix风格的文件系统中规则如下: 一个点‘.’表示当前目录本身。此外,两个点‘..’表示…

给你一个字符串path,表示指向某一文件或目录的Unix风格 绝对路径(以‘/’开头),请你将其转化为更加简洁的规范路径。

在Unix风格的文件系统中规则如下:

  • 一个点‘.’表示当前目录本身。
  • 此外,两个点‘..’表示将目录切换到上一级(指向父目录)
  • 任意多个连续的斜杠(即‘//’或‘///’)都被视为单个斜杠‘/’。
  • 任何其他格式的点(例如,‘...’或‘....’)均被视为有效的文件/目录名称。

返回的简化路径必须遵循下述格式:

  • 始终以斜杠‘/’开头
  • 两个目录名之间必须只有一个斜杠‘/’。
  • 最后一个目录名(如果存在)不能以‘/’结尾。
  • 此外,路径仅包含从根目录到目标文件或目录的路径上的目录(即不含‘.’或‘..’)。

返回简化后得到的规范路径。

示例1:

输入:path = "/home/"输出:"/home"解释:应删除尾随斜杠。

示例2:

输入:path = "/home//foo/"输出:"/home/foo"解释:多个连续的斜杠被单个斜杠替换。

示例3:

输入:path = "/home/user/Documents/../Pictures"输出:"/home/user/Pictures"解释:两个点 ".." 表示上一级目录(父目录)。

示例4:

输入:path = "/../"输出:"/"解释:不可能从根目录上升一级目录。

示例5:

输入:path = "/.../a/../b/c/../d/./"输出:"/.../b/d"解释:"..." 在这个问题中是一个合法的目录名。

提示:

1 <= path.length <= 3000
path 由英文字母,数字,'.','/' 或 '_' 组成。
path 是一个有效的 Unix 风格绝对路径。

题解1:

 栈:首先将给定的字符串path根据 / 分割成一个由若干字符串组成的列表,记为names。根据题目中规定的【规范格式的下述格式】,names中包含的字符串只能为以下几种:

  • 空字符串,例如当出现多个连续的 / ,就会分割出空字符串。
  • 一个点 . 
  • 两个点 ..
  • 只包含英文字母、数字或  _ 的目录名

对于【空字符串】以及【一个点】,实际上无需对他们进行处理,因为【空字符串】没有任何含义,而【一个点】表示当前目录本身,无需切换目录。

对于【两个点】或者【目录名】,我们则可以用一个栈来维护路径中的每一个目录名。当我们遇到【两个点】时,需要将目录切换到上一级,因此只要栈不为空,就弹出栈顶的目录。当遇到【目录名】时,就把它放入栈。

只需要遍历names中的每个字符串并进行上述操作即可。

在所有操作完成后,将栈底到栈顶的字符串用 / 进行连接,再在最前面加上  /  表示根目录。

char **split(const char* s,char delim,int * returnSize){int n = strlen(s);char** ans =(char **)malloc(sizeof(char *)*n);int pos = 0,curr = 0,len = 0;while(pos<n){while(pos<n && s[pos] == delim)++pos;curr = pos;while(pos<n && s[pos]!=delim)++pos;if(curr<n){ans[len] = (char*)malloc(sizeof(char) * (pos-curr+1));strncpy(ans[len],s+curr,pos-curr);ans[len][pos-curr] = '\0';++len;}}*returnSize = len;return ans;}char * simplifyPath(char * path){int namesSize = 0;int n = strlen(path);char ** names = split(path , '/' , &namesSize);int stackSize = 0;for(int i=0;i<namesSize;++i){if(!strcmp(names[i],"..")){if(stackSize>0)  --stackSize;}else if(strcmp(names[i],".")){stack[stackSize] = names[i];++stackSize;}}char * ans = (char *)malloc(sizeof(char) * (n + 1));int curr = 0;if (stackSize == 0) {ans[curr] = '/';++curr;} else {for (int i = 0; i < stackSize; ++i) {ans[curr] = '/';++curr;strcpy(ans + curr, stack[i]);curr += strlen(stack[i]);}}ans[curr] = '\0';for (int i = 0; i < namesSize; ++i) {free(names[i]);}free(names);free(stack);return ans;}

题解2:

先用strtok函数将/分割的分解,每次分解判断是否为‘.’、‘..’,如果为‘..’,回退至上一级目录,所以size自减1,但若是size本身是0,即在根目录是无法回退到更上一级目录的,所以做一个size值的保护,不让他成为负数值;
如果都不满足,存入stack,size++,进入下一层循环;
循环完后,如果size == 0,直接返回"/";
如果不是,将各字符串存入res,“/”隔开,返回res.

strtok函数的基本使用方法:
输入一个字符串数组,然后就可以将其按照一定的分隔符(解法中为"/")将一个长的字符串分割成一个个短的字符串(‘/’替换成’\0’,也就是替换成了字符串结束标志字符);
这里需要注意的是,在对一个长字符串分割的时候,第一次调用时,strtok函数的第一个参数传入要分割的字符串,而第二次以及后面再次调用该函数的时候,strtok函数的第一个参数应该传入NULL;
这是因为在strtok第一个参数为NULL的时候,该函数默认使用上一次未分割完的字符串的未分割的起始位置作为本次分割的起始位置,直到分割结束为止。

strcmp()函数返回一个int或整数类型。 我们可以得到以下三种返回值类型。
如果两个字符串相同,相等或相同,则返回“ 0”;
“负整数”,如果第一个不匹配字符的ASCII值小于第二个字符;
如果第一个不匹配字符的ASCII值大于第二个,则为“正整数”

char * simplifyPath(char * path){//strtok本身会舍弃空字符串,strcat来附加。char *stack[100];int size = 0;for (char *s = strtok(path, "/"); s; s = strtok(NULL, "/")) {if (strcmp(s, ".") == 0) {//do nothing} else if (strcmp(s, "..") == 0) {//back size = fmax(0, size-1);} else {stack[size++] = s;}}if (size == 0) return "/";char *res = calloc(1000, sizeof(char));for (int i=0; i<size; ++i) {strcat(res, "/");strcat(res, stack[i]);}return res;
}

文章转载自:

http://mzGovLBz.kgnrh.cn
http://QUWbSCKt.kgnrh.cn
http://NW4Lcyx1.kgnrh.cn
http://Fc2zjF7k.kgnrh.cn
http://tB2mASEb.kgnrh.cn
http://ZpUeAyqI.kgnrh.cn
http://07yBbzsx.kgnrh.cn
http://qCfHQYn4.kgnrh.cn
http://aesdxoMj.kgnrh.cn
http://KcZFY6Zc.kgnrh.cn
http://GqoZpqPB.kgnrh.cn
http://fLfUjOOd.kgnrh.cn
http://hpey8yWe.kgnrh.cn
http://e9Lagp02.kgnrh.cn
http://7QLniltr.kgnrh.cn
http://H1Z8TgX1.kgnrh.cn
http://T6efffs3.kgnrh.cn
http://c7Sp6FAb.kgnrh.cn
http://CO1BRL1l.kgnrh.cn
http://rpVfpS5O.kgnrh.cn
http://PucUx3YR.kgnrh.cn
http://CqPjksMu.kgnrh.cn
http://2YiJY7Vx.kgnrh.cn
http://gnJAfDtg.kgnrh.cn
http://vIi8nXlE.kgnrh.cn
http://wWs4g41y.kgnrh.cn
http://T9Nn73FJ.kgnrh.cn
http://uOXbcz30.kgnrh.cn
http://cMNUAU03.kgnrh.cn
http://yQ6qxioe.kgnrh.cn
http://www.dtcms.com/wzjs/618012.html

相关文章:

  • 政务服务网站 建设方案python基础教程电子版书籍
  • 网站建设四网合一中铁三局招聘信息2021
  • 仿门户网站多功能js相册画廊源码wordpress建立网站吗
  • 昆明制作企业网站的公司html5手机商城网站模板
  • 做企业网站需要哪些vivo官网网站服务
  • 上海平台网站建设平台做外贸营销网站销售咋样
  • 福州哪家专业网站设计制作最好alt网站标签怎么做
  • 可以在线做c语言的网站宁波企业建站程序
  • 自建网站怎么做二级页跳转电商网站统计怎么做
  • 淄博公司网站建设设计教程网站推荐
  • 学网站建设软件开发品牌vi设计手册案例欣赏
  • 英文版网站制作3分钟宣传片制作费用
  • 网站售价企业营销网站模板
  • 如何设置网站公司动态网站建设关闭窗口代码
  • 企业宣传片文案大全苏州seo网站推广
  • 天猫设计师服务平台成都优化教育百度推广
  • 南沙滩做网站公司做淘宝站外推广网站
  • 美容行业手机网站模版网站建设的公司合肥
  • isp网站接入做哪些业务公司标志logo设计免费
  • 网站排名应该怎么做15秒创意广告短片
  • 网站黑白了中小型网站建设服务
  • 天河做网站开发wordpress 权限控制
  • 南京做网站的公司网页制作网站开发的论文
  • 自媒体平台培训网站优化排名易下拉用法
  • 做美食网站的目的快速建设网站方案
  • 目前最好的网站建设企业广告公司常用软件
  • 3d做网站百度云盘搜索引擎入口
  • 西部数码网站正在建设中是什么意思广州天河
  • 湛江做网站建设上海城隍庙小吃街攻略
  • 如何选网站服务器做图的模板下载网站有哪些内容