Simplify Path

本文介绍了一种简化Unix文件路径的方法,通过解析输入的绝对路径并处理各种特殊情况,如多个连续的斜杠、相对路径符号等,最终返回规范化的路径。

Given an absolute path for a file (Unix-style), simplify it.

For example,
path = "/home/", => "/home"
path = "/a/./b/../../c/", => "/c"

click to show corner cases.

Corner Cases:

  • Did you consider the case where path = "/../"?
    In this case, you should return "/".
  • Another corner case is the path might contain multiple slashes '/' together, such as "/home//foo/".
    In this case, you should ignore redundant slashes and return "/home/foo".

此题的很多特殊情况,此处代码写的不是很好!

为 . ..  字母目录,(特别是为空的情况,在此次使用了一个back_root 标志位,并且下一次还是为/重复,去重!)

返回只有在/..才返回!../ 输出为..  

string simplifyPath(string path) 
{
	if(path.empty())return path;

	int pos = 0;
	string res;
	bool back_root = false;
	while(pos < path.size())
	{
		if(path[pos] == '/' || back_root)
		{
			back_root = false;
			if(path[pos+1] == '\0' )//处理要结束的情况
			{
				break;
			}
			else if(pos +3 <= path.size()&&path[pos+1] == '.' &&path[pos+2] == '.'&&(path[pos+3] == '/'||path[pos+3] == '\0'))//..的情况

			{
				if(!res.empty())
				{
					res = res.substr(0,res.rfind('/'));//上一个地方
				}
				else
				{
					back_root = true;
					res = "/";
				}
				pos = pos + 3;
			}
			else if(pos +2 <= path.size()&&path[pos+1] == '.'&&(path[pos+2] == '/'||path[pos+2] == '\0'))// .的情况 

			{
				pos = pos + 2;
			}
			else if((res.size() >= 1&&res[res.size()-1]=='/')||path[pos+1] == '/') //处理 /// 多个情况,以及返回为空res多一个/也要在此处处理
			{
				pos++;
			}
			else//处理字母目录
			{
				
				int start = pos;
				pos++;
				while(path[pos] != '/'&&path[pos] !='\0')
				{
					pos++;
				}
				res = res + path.substr(start,pos-start);
			}
		}
		else  //处理 非/的情况!!全部加入
		{
			res += path[pos];
			pos++;
		}


	}
	if(res.empty())res = "/";
	return res;
}


第二次:

用一个vcetor模拟栈的功能,只存储字符串。/后续的补上

string simplifyPath(string path) 
{
	if(path.empty())return path;

	vector<string> path_vec;
	
	int pos = 0;
	while(pos < path.size()&& pos != -1 )
	{
		if(path[pos] == '/')
		{
			pos++;
			 
		    int pos_end = path.find('/',pos);
			string sub_str ;

			if(pos_end == -1)//未找到
			{
				sub_str = path.substr(pos);
			}
			else
			{
				sub_str = path.substr(pos,pos_end-pos);
			}
			

			if (sub_str == ".." )
			{
				if(!path_vec.empty())
				{
					path_vec.pop_back();
				}
				pos = pos_end;
			}
			else if (sub_str == "."||sub_str == "")//只需后面移动位置,sub_str == ""为/
			{
			  pos = pos_end;
			}
			else
			{
				path_vec.push_back(sub_str);
				pos = pos_end;
			}
			
		}
		
	}
	string res;

	for (int i = 0;i < path_vec.size();i++)
	{
		res +="/"+ path_vec[i];
	}
	if (path_vec.empty())
	{
		res = "/";
	}
	return res;
}



### Simplify3D 使用教程 #### 一、界面操作基础 对于初次接触Simplify3D的用户来说,了解其基本的操作方式至关重要。通过鼠标的不同按键可以实现多种视角调整功能: - 右键用于移动视野[^4]。 - 左键负责旋转视野[^4]。 - 中键以及滚轮均可用来恢复默认视图[^3]。 这些简单的交互手段能够帮助使用者快速上手并熟悉软件环境。 #### 二、打印机配置初始化 首次启动该程序时需完成一个重要步骤——定义所使用的3D打印设备规格。具体做法如下:点击菜单栏中的“工具”,随后选择“选项”。在此处输入或修改当前连接至计算机上的实际硬件参数,比如尺寸等信息。这一步骤确保了后续所有的切片处理都能精准匹配特定型号的需求。 #### 三、单位设置建议 为了使各项参数更加直观易懂,在速度方面推荐采用毫米每秒作为计量标准。这种标准化的做法不仅有助于提高工作效率,同时也减少了因误解而产生的错误风险。 #### 四、模型加载流程 当一切准备就绪之后就可以着手导入待加工的对象文件了。通常情况下只需按照提示依次执行相应命令即可顺利完成这一过程。 ```python # 假设有一个Python脚本辅助自动化某些重复性的任务 import os def load_model(file_path): """模拟加载STL或其他支持格式的3D模型""" if not os.path.exists(file_path): raise FileNotFoundError(f"The specified file does not exist: {file_path}") print(f"Loading model from '{file_path}'...") # 这里省略具体的加载逻辑... ```
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值