问题 E: 档案管理
时间限制: 1 Sec 内存限制: 128 MB
提交: 274 解决: 105
[
提交][
状态][
讨论版]
题目描述
X老师管理着学校的档案室,经常会有其他的老师来档案室存文件和取文件,每次有老师来取文件时,X老师就要在档案室里苦苦的找文件。你是X老师的学生,得知了X老师找文件很辛苦后,想为X老师写个文件管理程序,这对学计算机专业的你来说只是小Case。你的程序的功能有:
1 file1 //.给新文件file1添加一个新的编号
2 file2 //根据输入的文件名file2输出其相应的文件编号。
输入
先输入一个整数n。0<n<101。代表有n次操作,接下来有n行,每行有一个整数(1或2),表示相应的操作(添加或查找),和一个文件名(由小写字母组成,长度不超过20),表示相应的操作对象。测试数据保证同一个文件不会被添加两次
输出
对于每个2型操作输出一行,即被查找文件相应的编号,若文件不存在则输出”The file does not exist”。
样例输入
5
1 xueshengziliao
2 abcd
2 xueshengziliao
1 abcd
2 abcd
样例输出
The file does not exist
1
2开始以为要用map,,,后来在提交的时候wa了3发,然后老老实实用的数组过的,。。
#include <cstdio>
#include <cstring>
int main()
{
char c[
110][
22],s[
22];
int n,a,k=
0,j,f;
scanf("%d",&
n);
for(
int i=
1;i<=n;i++
)
{
scanf("%d %s",&
a,s);
if(a==
1)
{
strcpy(c[++
k],s);
// printf(",,%s,,",c[k]);
}
else if(a==
2)
{
for(j=
1,f=
0;j<=k;j++
)
{
if(!
strcmp(c[j],s))
{
f=
1;
break;
}
}
if(f) printf(
"%d\n",j);
else printf(
"The file does not exist\n");
}
}
return 0;
}
View Code
转载于:https://www.cnblogs.com/wandso/p/10062076.html