每日一练

该程序设计题目要求从一系列不超过5个字符的字符串中,读取用户输入并找出最大的字符串。当遇到字符串'*****'时,输入结束。实现此功能的函数`find`通过比较字符串大小找到最大串,并输出。程序使用`strcmp`函数直接比较字符串大小,无需先比较长度。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

目录

1176:题目描述

                从键盘上输入多个字符串(每个串不超过5个字符且没有空格),用”*****”作为串输入结束的标记。从所输入的若干字符串中,找出一个最大的串,并输出该串。要求最大串的查找通过调用编写的函数实现

答案:


1176:题目描述

从键盘上输入多个字符串(每个串不超过5个字符且没有空格),用”*****”作为串输入结束的标记。从所输入的若干字符串中,找出一个最大的串,并输出该串。要求最大串的查找通过调用编写的函数实现


void find(char *name[], int n, int *p)
{
//在包含n个字符串的二维字符数组name中,查找值最大的字符串,将其下标存入指针p所指内存单元
}


输入

一行输入一个字符串,输入多行

输出

输出一个字符串,单独占一行。

答案:

# include<stdio.h>
# include<string.h>
# include<stdlib.h>
void find(char *name[], int n, int *p);
int main()
{
	char *str[1000],s[6];
	int i=0,max=0;
	while(gets(s))
		if(strcmp(s,"*****")!=0)
		{
			str[i++]=(char *)malloc(sizeof(char)*6);
			strcpy(str[i-1],s);
		}
		else
			break;
	find(str,i,&max);
	return 0;
}
void find(char *name[], int n, int *p)
{
	int i,a[n],j;
//	for(i=0; i<n; i++)
//		if(strlen(name[*p])<=strlen(name[i]))
//			if(strcmp(name[*p],name[i])<0)
//				*p=i;
	for(i=1; i<n; i++)
		if(strcmp(name[i],name[*p])>0)
			*p=i;
	printf("%s\n",name[*p]);
}

ps:

直接strcmp比较就可以

屏蔽部分为:先比较长度,再比大小,输出ascll码总值大的

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值