问题描述
寻找若干行文本中最长的一行
输入说明
输入为多个字符串(每个字符串长度不超过100个字符),每个字符串占一行,输入的行为“***end***”时表示输入结束
输出说明
输出其中最长的一行长度后换行再输出最长行的内容,如果最长行不止一个,则输出其中的第一行。
输入样例
abce
abdf dlfd
end
当
char a[100][100];
int i,j,n,m=0;
for(i=0;;i++)
{gets(a[i]);
if(m=(strcmp(a[i],"***end***"))==0) break;}
可以从循环中出来
但当
for(i=0;;i++)
{gets(a[i]);
if(a[i]=="***end***") break;
就不行,一直处于循环中;
以下是全代码,请大神们帮看看有什么问题,oj上一直是结果错误
#include<stdio.h>
#include<string.h>
int main()
{
char a[100][100];
int i,j,n,m=0;
for(i=0;;i++)
{gets(a[i]);
if(m=(strcmp(a[i],"***end***"))==0) break;}
for(j=0;j<i;j++)
{
if(strlen(a[j])<strlen(a[j+1])) n=j+1;
else n=j;}
printf("%d\n%s",strlen(a[n]),a[n]);
return 0;
}