展开全部
C语言代码如下
自己做的,并写注释了.很容易懂.不懂到我百度空间留言
#include<stdio.h>
#include<string.h>
voidmain()
{
charstr[5][50],max[50];
inti,j;
printf("输入5个字符串:\n");
fflush(stdin);//清空缓存
for(i=0;i<5;i++)
{
gets(str[i]);//从键盘输入,也可以用scanf("%s",&str[i])的方法输入
}
/*
下面是关键,适应strlen()字符串的长度和字符串的比较strcmp(),还有字符串的赋值strcpy()
我会使用字符串的冒泡排序让输入的字符串从大到小排列,那么数组的第一个字符串就是最长的.
*/
for(i=1;i<=5;i++)//需要比较字符串的个数
{
for(j=0;j<5-i;j++)//需要比较的伦数,因为没比较一次就会减少一个字符串,所以用5-i(i自动增长1的变量)
{
if(strcmp(str[j],str[j+1])<0)//strcmp()比较字符串的字符的ASCII的值,第一个"大"返回整数正1(>0),等于返回0(=0),小于返回-1(<0)
{
strcpy(max,str[j]);
strcpy(str[j],str[j+1]);
strcpy(str[j+1],max);
}
}
}
printf("最长的字符串为:%s,他的长度为:%d",str[0],strlen(str[0]));
}
自己做的,并写注释了.很容易懂.不懂到我百度空间留言
#include<stdio.h>
#include<string.h>
voidmain()
{
charstr[5][50],max[50];
inti,j;
printf("输入5个字符串:\n");
fflush(stdin);//清空缓存
for(i=0;i<5;i++)
{
gets(str[i]);//从键盘输入,也可以用scanf("%s",&str[i])的方法输入
}
/*
下面是关键,适应strlen()字符串的长度和字符串的比较strcmp(),还有字符串的赋值strcpy()
我会使用字符串的冒泡排序让输入的字符串从大到小排列,那么数组的第一个字符串就是最长的.
*/
for(i=1;i<=5;i++)//需要比较字符串的个数
{
for(j=0;j<5-i;j++)//需要比较的伦数,因为没比较一次就会减少一个字符串,所以用5-i(i自动增长1的变量)
{
if(strcmp(str[j],str[j+1])<0)//strcmp()比较字符串的字符的ASCII的值,第一个"大"返回整数正1(>0),等于返回0(=0),小于返回-1(<0)
{
strcpy(max,str[j]);
strcpy(str[j],str[j+1]);
strcpy(str[j+1],max);
}
}
}
printf("最长的字符串为:%s,他的长度为:%d",str[0],strlen(str[0]));
}
展开全部
楼上的方法可以,如果用C++的话相对简单点:
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
bool MaxSize(const string& lhs, const string& rhs)
{
return lhs.size() < rhs.size();
}
int main()
{
string max;
cout << "Enter a line of word, press CTRL + X simultaneously to stop:\n";
max = *max_element(istream_iterator<string>(cin), istream_iterator<string>(), MaxSize);
cout << "The word with the max size is: " << max << endl;
}
如果要用list或者string数组或者char二维的话也是一样的,我就不再多写了。
#include <iostream>
#include <string>
#include <algorithm>
using namespace std;
bool MaxSize(const string& lhs, const string& rhs)
{
return lhs.size() < rhs.size();
}
int main()
{
string max;
cout << "Enter a line of word, press CTRL + X simultaneously to stop:\n";
max = *max_element(istream_iterator<string>(cin), istream_iterator<string>(), MaxSize);
cout << "The word with the max size is: " << max << endl;
}
如果要用list或者string数组或者char二维的话也是一样的,我就不再多写了。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
C语言代码如下
自己做的,并写注释了.很容易懂.不懂到我百度空间留言
#include <stdio.h>
#include <string.h>
void main()
{
char str[5][50], max[50];
int i,j;
printf("输入5个字符串:\n");
fflush(stdin);//清空缓存
for(i=0;i<5;i++)
{
gets(str[i]);//从键盘输入,也可以用scanf("%s",&str[i])的方法输入
}
/*
下面是关键,适应strlen()字符串的长度和字符串的比较strcmp(),还有字符串的赋值strcpy()
我会使用字符串的冒泡排序让输入的字符串从大到小排列,那么数组的第一个字符串就是最长的.
*/
for(i=1;i<=5;i++)//需要比较字符串的个数
{
for(j=0;j<5-i;j++)//需要比较的伦数,因为没比较一次就会减少一个字符串,所以用5-i(i自动增长1的变量)
{
if(strcmp(str[j],str[j+1])<0)//strcmp()比较字符串的字符的ASCII的值,第一个"大"返回整数正1(>0),等于返回0(=0),小于返回-1(<0)
{
strcpy(max,str[j]);
strcpy(str[j],str[j+1]);
strcpy(str[j+1],max);
}
}
}
printf("最长的字符串为:%s,他的长度为:%d",str[0],strlen(str[0]));
}
自己做的,并写注释了.很容易懂.不懂到我百度空间留言
#include <stdio.h>
#include <string.h>
void main()
{
char str[5][50], max[50];
int i,j;
printf("输入5个字符串:\n");
fflush(stdin);//清空缓存
for(i=0;i<5;i++)
{
gets(str[i]);//从键盘输入,也可以用scanf("%s",&str[i])的方法输入
}
/*
下面是关键,适应strlen()字符串的长度和字符串的比较strcmp(),还有字符串的赋值strcpy()
我会使用字符串的冒泡排序让输入的字符串从大到小排列,那么数组的第一个字符串就是最长的.
*/
for(i=1;i<=5;i++)//需要比较字符串的个数
{
for(j=0;j<5-i;j++)//需要比较的伦数,因为没比较一次就会减少一个字符串,所以用5-i(i自动增长1的变量)
{
if(strcmp(str[j],str[j+1])<0)//strcmp()比较字符串的字符的ASCII的值,第一个"大"返回整数正1(>0),等于返回0(=0),小于返回-1(<0)
{
strcpy(max,str[j]);
strcpy(str[j],str[j+1]);
strcpy(str[j+1],max);
}
}
}
printf("最长的字符串为:%s,他的长度为:%d",str[0],strlen(str[0]));
}
本回答被提问者采纳
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询