栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 面试经验 > 面试问答

zoj 1809 File Mapping

面试问答 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

zoj 1809 File Mapping

#include<iostream>#include<vector>#include<string.h>#include<stdio.h>#include<algorithm>using namespace std;const string delim = "|     ";struct Dir {string name;vector<string> filelist;vector<int> subdir;};Dir save[200];int start,root;int getDir(){save[start].filelist.clear(); save[start].subdir.clear();return start ++;}void scandir(Dir &d){static string s;int t;cin>>s;while(s!="]"){if(s[0] == 'f'){d.filelist.push_back(s);} else {t = getDir();save[t].name = s;d.subdir.push_back(t);scandir(save[t]);}cin>>s;}}void printlevel(int l){while(l --){cout<<delim;}}void output(Dir &d, int level){sort(d.filelist.begin(),d.filelist.end(),less<string>() );printlevel(level);cout<<d.name<<endl;int i;for(i=0;i<d.subdir.size();i++){output( save[d.subdir[i]],level+1);}for(i=0;i<d.filelist.size();i++){printlevel(level);cout<<d.filelist[i]<<endl;}}int main(){int tstcase = 0;string s;cin>>s;while(s!="#"){if(tstcase ++ )cout<<endl;start = 0; root= getDir();save[root].name = "ROOT";while(s!="*"){if(s[0] == 'f'){save[root].filelist.push_back(s);} else { int t = getDir();save[t].name = s;save[root].subdir.push_back(t);scandir(save[t]);}cin>>s;}cout<<"DATA SET "<<tstcase<<":"<<endl;output(save[root],0);cin>>s;}return 0;}
转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/379043.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号