输入格式:
第一行给出一个整数N(1<=n<=10),接下来N行,每行给出一行字符串S(长度<100)。所有样例保证出现最多的变量名称唯一,且程序语句无错误(类型名称 变量名称 = 值)。但是在语句正确的情况下不保证无多余空格。每一行仅包含一个语句。定义不包含const等修饰符。
输出格式:
程序结束后你需要输出重名最多的变量名称和它重复了多少次。
输入样例:
5
int a = 2;
int b = 3;
double k = 5.625;
char a = 'a';
float a = 1.567;
输出样例:
a 3
tips:变量名为每一行第二个单词
这题重要的就是如何区分并保存变量名。
对于我刚入门的新手;
输入字符串的方法就两种:
一是scanf("%s",&..)这个可以区分出空格或换行符并停止,但这题给出的条件给出的是“变量名为每一行第二个单词”。这就导致不确定一行有几个不含空格的字符串,单用sacnf不足以满足要求。
二是gets ,它能一直执行到遇到换行符才停止。
所以我的想法是先用scanf区分并储存变量名后用gets消除一行中多余的字符。
话不多说,上代码:
#include<stdio.h>
#include<string.h>
int main()
{
char bian[20][100],leiXing[20],duoyu[50];
int n,i,j,max=0,m,x;
scanf("%d",&n);
for(i=1;i<=n;i++)
{
scanf("%s%s",&leiXing,&bian[i]);
gets(duoyu);
}
for(i=1;i<=n;i++)
{
m=0;
for(j=i;j<=n;j++)
if(strcmp(bian[i],bian[j])==0)m++;
if(m>max)max=m,x=i;
}
printf("%s %d",bian[x],max);
}