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

定制网站和模板网站及仿站的区别百度站长工具怎么关闭教程视频

定制网站和模板网站及仿站的区别,百度站长工具怎么关闭教程视频,wordpress后台密码忘记了怎么办,手机网站模板源码下载给你一个字符串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://www.dtcms.com/wzjs/119815.html

相关文章:

  • 手机端网站建设教程网络营销的工具有哪些
  • 网页打不开无法访问此网站百度免费注册
  • 广州市专业做商城网站谷歌推广代理
  • 做英文网站 是每个单词首字母大写 还是每段落首字母大写短链接
  • 公司做的网站费用如何做账北京优化推广公司
  • asp商品网站源码怎么推广公司网站
  • 做其他国家语言网站网络营销师证书查询
  • 北京网站制作培训机构百度网址大全官网旧版
  • 深圳手机网站建设网站死链检测工具
  • wordpress 改网站介绍爱站网工具
  • 建设银行如何注销网站信息班级优化大师的优点
  • wordpress 多作者郑州seo推广优化
  • 电商静态网页模板谷歌优化排名哪家强
  • 网站建设与规划网络营销服务公司
  • 潍坊做网站建设的公司怎么用模板做网站
  • 档案互动网站建设新闻网站排行榜
  • 安康公司网站制作爱站seo
  • wordpress分类产品电脑系统优化工具
  • 新型建站技术网络营销课程个人总结
  • 做景观园林的网站是杭州关键词优化测试
  • 阿里云nas做网站排名
  • 南昌做网站开发的公司哪家好北京seo课程培训
  • 网站开发 微信收款seo推广软件哪个好
  • 模拟黑客网站google下载官方版
  • 短视频网站开发深圳优化怎么做搜索
  • swoole做网站大型网站建设平台
  • 西安建网站怎么买域名自己做网站
  • wordpress改雅黑河源市企业网站seo价格
  • 北京P2P公司网站建设广州seo网站排名
  • 中华室内设计网节点图seo网络优化平台