杭电1004,在我的代码的基础上帮我指出错误! 我真的看不出来哪里错了!测试数据输出没错,可是交上去是WA
#include<stdio.h>#include<string.h>intmain(){intn,i,k[1001],j,max;chara[1001][15];whi...
#include<stdio.h>
#include<string.h>
int main()
{
int n,i,k[1001],j,max;
char a[1001][15];
while(scanf("%d",&n)!=EOF)
{
if(n==0)break;
for(i=0;i<n;i++)
{
scanf("%s",a[i]);
}
for(i=0;i<n-1;i++)
{
k[i]=0;
for(j=i+1;j<n;j++)
{
if(strcmp(a[i],a[j])==0)
{
k[i]+=1;
}
}
}
max=0;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
if(k[i]<k[j])
max=j;
}
printf("%s\n",a[max]);
}
return 0;
} 展开
#include<string.h>
int main()
{
int n,i,k[1001],j,max;
char a[1001][15];
while(scanf("%d",&n)!=EOF)
{
if(n==0)break;
for(i=0;i<n;i++)
{
scanf("%s",a[i]);
}
for(i=0;i<n-1;i++)
{
k[i]=0;
for(j=i+1;j<n;j++)
{
if(strcmp(a[i],a[j])==0)
{
k[i]+=1;
}
}
}
max=0;
for(i=0;i<n-1;i++)
{
for(j=i+1;j<n;j++)
if(k[i]<k[j])
max=j;
}
printf("%s\n",a[max]);
}
return 0;
} 展开
2个回答
展开全部
/*k不需要保存,把你两个循环给合并了,既省空间又省时间。下面是AC的代码
如果你一定要用k[]保存的话要把最后的循环改掉,那个最大值是错的,只要i到max后面遇到比i大的j就会被j覆盖
int m = k[0];
for(i=0;i<n-1;i++) {
if(m<k[i]) {
m = k[i];
max=i;
}
}
*/
#include<stdio.h>
#include<string.h>
int main()
{
int n,i,k,j,m,max;
char a[1001][15];
while(scanf("%d",&n)!=EOF)
{
if(n==0)break;
for(i=0;i<n;i++)
{
scanf("%s",a[i]);
}
for(i=0, m=0;i<n-1;i++)
{
k=0;
for(j=i+1;j<n;j++)
{
if(strcmp(a[i],a[j])==0)
{
k+=1;
}
}
if(m<k)
{
m=k;
max = i;
}
}
printf("%s\n",a[max]);
}
return 0;
}
如果你一定要用k[]保存的话要把最后的循环改掉,那个最大值是错的,只要i到max后面遇到比i大的j就会被j覆盖
int m = k[0];
for(i=0;i<n-1;i++) {
if(m<k[i]) {
m = k[i];
max=i;
}
}
*/
#include<stdio.h>
#include<string.h>
int main()
{
int n,i,k,j,m,max;
char a[1001][15];
while(scanf("%d",&n)!=EOF)
{
if(n==0)break;
for(i=0;i<n;i++)
{
scanf("%s",a[i]);
}
for(i=0, m=0;i<n-1;i++)
{
k=0;
for(j=i+1;j<n;j++)
{
if(strcmp(a[i],a[j])==0)
{
k+=1;
}
}
if(m<k)
{
m=k;
max = i;
}
}
printf("%s\n",a[max]);
}
return 0;
}
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询