XDOJ目录操作

标题

目录操作

类别

字符串处理

时间限制

1S

内存限制

256Kb

问题描述

在操作系统中,文件系统一般采用层次化的组织形式,由目录(或者文件夹)和文件构成,形成一棵树的形状。

有一个特殊的目录被称为根目录,是整个文件系统形成的这棵树的根节点,在类Linux系统中用一个单独的 “/”符号表示。

因此一个目录的绝对路径可以表示为“/d2/d3”这样的形式。

当前目录表示用户目前正在工作的目录。为了切换到文件系统中的某个目录,可以使用“cd”命令。

假设当前目录为“/d2/d3”,下图给出了cd命令的几种形式,以及执行命令之后的当前目录。

现在给出初始时的当前目录和一系列目录操作指令,请给出操作完成后的当前目录。 

输入说明

第一行包含一个字符串,表示当前目录。

后续若干行,每行包含一个字符串,表示需要进行的目录切换命令。

最后一行为pwd命令,表示输出当前目录

注意:

1. 所有目录的名字只包含小写字母和数字,cd命令和pwd命令也都是小写。最长目录长度不超过200个字符。

2. 当前目录已经是根目录时,cd .. 和cd /不会产生任何作用

输出说明

输出一个字符串,表示经过一系列目录操作后的当前目录

输入样例

/d2/d3/d7

cd ..

cd /

cd /d1/d6

cd d4/d5

pwd

输出样例

/d1/d6/d4/d5

#include<stdio.h>
#include<string.h>
int main()
{
	char s[200]={};
	gets(s);
	while(1)
	{
		char t[200]={};//t仅用来进行命令判断 
		gets(t);
		int l=strlen(s);//t的长度 
		if(strcmp(t,"pwd")==0)
		{
			break;
		}//退出 
		else if(strcmp(t,"cd /")==0)
		{
         if(strcmp(s,"/")!=0)
         {
		 	        strcpy(s,"/");//返回主目录 
		 }
		}
		else if(strcmp(t,"cd ..")==0)
		{
         if(strcmp(s,"/")!=0)
         {
		 				int i=l-1; 
			 			while(s[i]!='/')
			 			{
			 				s[i]='\0';
			 				i--;
			 			}
			 			s[i]='\0';//返回上级目录 
		 }
		}
		else if(t[3]!='/')
		{
			char tt[200]={};
            if(strcmp(s,"/")!=0)
            {
							tt[0]='/';
							int j=1;
							for(int i=3;i<strlen(t);i++)
							{
								tt[j]=t[i];
								j++;
							}
							tt[j]='\0';
							strcat(s,tt);//子目录 
			}
			else
			{
							int j=0;
							for(int i=3;i<strlen(t);i++)
							{
								tt[j]=t[i];
								j++;
							}
							tt[j]='\0';
							strcat(s,tt);//子目录 
			}
		}
		else 
		{
			char tt[200]={};
			int j=0;
			for(int i=3;i<strlen(t);i++)
			{
				tt[j]=t[i];
				j++;
			}
			tt[j]='\0';
			strcpy(s,tt);//新目录 
		}
	}
	printf("%s",s);
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值