问题 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[][],s[];
int n,a,k=,j,f;
scanf("%d",&n);
for(int i=;i<=n;i++)
{
scanf("%d %s",&a,s);
if(a==)
{
strcpy(c[++k],s);
// printf(",,%s,,",c[k]);
}
else if(a==)
{
for(j=,f=;j<=k;j++)
{
if(!strcmp(c[j],s))
{
f=;
break;
}
}
if(f) printf("%d\n",j);
else printf("The file does not exist\n");
}
}
return ;
}