1 定义二维数组存储字符串。
2 通过strcmp比较大小,strcpy进行赋值,实现排序。
3 输出结果。
代码:
int main(){
char s[3][100], t[100]
int i,j
for(i =0 i < 3 i ++)
scanf("%s",s[i])
for(i =0 i < 2 i ++)
for(j = i+1 j <3 j ++)
if(strcmp(s[i],s[j])>0)
{
strcpy(t,s[i])
strcpy(s[i],s[j])
strcpy(s[j],t)
}
for(i =0 i < 3 i ++)
puts(s[i])
}
什么最大?字符串长度?ASC码总和?还是说是纯数字的字符串,作为数字来比较大小?
我把几种情况都写了。你参考吧。
多个相等的最大值,只返回其中1个
#include <stdio.h>#include <stdlib.h>
#include <malloc.h>
#include <string.h>
int getsum(char *str)//获取字符串ASC总和
char *getmax(int num[3])//3个整数型的数字比较,返回最大的那个数组下标 如果多个最大值返回多个下标(用字符串保存)
int getmax2(char str[][10])//3个字符型的数字比较,返回最大的那个数组下标
int main()
{
char str[3][10]
int indext
int len[3]//3个字符串长度
int sum[3]//3个字符串的ASC码总和
printf("测试:输入3个字符串(最多9个字符):\n")
scanf("%s",&str[0][0])
scanf("%s",&str[1][0])
scanf("%s",&str[2][0])
len[0]=strlen(&str[0][0])len[1]=strlen(&str[1][0])len[2]=strlen(&str[2][0])//获取3个字符串长度
sum[0]=strlen(&str[0][0])sum[1]=strlen(&str[1][0])sum[2]=strlen(&str[2][0])//获取3个字符串的ASC码总和
indext=getmax(len)[0]-'0'
printf("字符串长度最大的是:%s\n",&str[indext][0])
indext=getmax(sum)[0]-'0'
printf("ASC码值和最大的是: %s\n",&str[indext][0])
printf("作为数字比最大的是:%s\n",&str[getmax2(str)][0])
return 1
}
int getsum(char *str)//获取字符串ASC总和
{
int len=strlen(str),i,sum=0
for(i=0i<leni++)
{
sum=sum+(int)str[i]
}
return sum
}
char *getmax(int num[3])//3个整数型的数字比较,返回最大的那个数组下标 如果多个最大值返回多个下标
{
char *renum=(char *)malloc(sizeof(char)*4)
memset(renum,0,4)
if(num[0]>=num[1] && num[0]>=num[2])
{
if(renum[0]==0)
renum[0]='0'
else if(renum[1]==0)
renum[1]='0'
else if(renum[2]==0)
renum[2]='0'
}
if(num[1]>=num[2] && num[1]>=num[0])
{
if(renum[0]==0)
renum[0]='1'
else if(renum[1]==0)
renum[1]='1'
else if(renum[2]==0)
renum[2]='1'
}
if(num[2]>=num[1] && num[2]>=num[0])
{
if(renum[0]==0)
renum[0]='2'
else if(renum[1]==0)
renum[1]='2'
else if(renum[2]==0)
renum[2]='2'
}
return renum
}
int getmax2(char str[][10])//3个字符型的数字比较,返回最大的那个数组下标
{
int len[3],i,maxlen,num[3]
char *renum=NULL
len[0]=strlen(&str[0][0])
len[1]=strlen(&str[1][0])
len[2]=strlen(&str[2][0])
if(len[0]>len[1] && len[0]>len[2])
return 0
if(len[1]>len[2] && len[1]>len[0])
return 1
if(len[2]>len[1] && len[2]>len[0])
return 2
maxlen=len[0]
if(maxlen<len[1])
maxlen=len[1]
if(maxlen<len[2])
maxlen=len[2]
for(i=0i<maxleni++)
{
if(maxlen-len[0]==0)
num[0]=str[0][i]-'0'
else
num[0]=-1
if(maxlen-len[1]==0)
num[1]=str[1][i]-'0'
else
num[1]=-1
if(maxlen-len[2]==0)
num[2]=str[2][i]-'0'
else
num[2]=-1
renum=getmax(num)
if(strlen(renum)==1)//如果当前位比较,得到唯一最大值,则返回下标
return renum[0]-'0'
if(strlen(renum)>1 && i==maxlen-1)//如果已比较到最后1位,且数值相等,则返回第一个最大值下标
return renum[0]-'0'
}
return -1
}
#include <stdio.h>
#include <string.h>
int main()
{
char a[100]={0}
char b[100]={0}
char c[100]={0}
scanf("%s%s%s",a ,b ,c )
while(1)
{
if(strcmp(a,b)<0&&strcmp(a,c)<0)
{
printf("最小是: %s\n",a)
break
}
if(strcmp(c,b)>0)
{
printf("最小是:%s\n",b)
break
}
else
{
printf("最小是: %s\n",c)
break
}
}
return 0
}
运行效果:
扩展资料:一、return在函数中的作用
我们如果将函数看做一个加工厂,参数就是我们向加工厂投入的原料,具体的函数功能实际上就是加工的过程,而return语句代表返回值,就是加工厂在实现加工之后给“投资人”的成品。
二、return语句的特点
1、在函数当中,遇到return语句之后就意味着函数运行的结束,在此之后的代码是不运行的。
2、它不支持任何运算也没有任何内建方法,和任何其他的数据类型比较是否相等时永远返回false,也可以将None赋值给任何变量。
3、执行到return语句时,会退出函数,return之后的语句不再执行。但将return语句放在try语句块中,是个例外。
三、return的默认值:return函数默认的返回值为undefined。