編程題
編寫一個(gè)函數(shù),從num個(gè)字符串中找出最長的一個(gè)字符串,并通過形參指針max傳回該串地址。(注意: 主函數(shù)中用****作為結(jié)束輸入的標(biāo)志,函數(shù)fun中給出的語句僅供參考。)
注意:部分源程序在文件PROG1.C中。
請勿改動(dòng)主函數(shù)main和其它函數(shù)中的任何內(nèi)容,僅在函數(shù)fun的花括號(hào)中填入你編寫的若干語句。
給定源程序:
#include
#include
fun(char(*a)[81],int num,char **max)
{
int i,k=0,len, maxlen; /* k為a數(shù)組中最長串所在元素的下標(biāo),初始為0,maxlen為其串
長 */
maxlen=strlen(a[k]);
for(i=1;i { /* 以下完成查找最長串 */ } *max=a[k]; } main() { char ss[10][81],*ps; int n,i=0; printf("輸入若干個(gè)字符串:"); gets(ss[i]); puts(ss[i]); while(!strcmp(ss[i],"****")==0) { i++; gets(ss[i]); puts(ss[i]); } n=i; fun(ss,n,&ps); printf("\nmax=%s\n",ps); NONO(); } 解題思路: 本題是考察考生怎樣從已輸入的字符串中找出長度最大的字符串。求字符串的長度可以使用strlen函數(shù)。 參考答案: fun(char(*a)[81],int num,char **max) { int i,k=0,maxlen; /* k為a數(shù)組中最長串所在元素的下標(biāo),初始為0,maxlen為其串長 */ maxlen=strlen(a[k]); for(i=1;i { /* 以下完成查找最長串 */ if(strlen(a[i]) > maxlen) { maxlen = strlen(a[i]) ; k = i ; } } *max=a[k]; }
北京 | 天津 | 上海 | 江蘇 | 山東 |
安徽 | 浙江 | 江西 | 福建 | 深圳 |
廣東 | 河北 | 湖南 | 廣西 | 河南 |
海南 | 湖北 | 四川 | 重慶 | 云南 |
貴州 | 西藏 | 新疆 | 陜西 | 山西 |
寧夏 | 甘肅 | 青海 | 遼寧 | 吉林 |
黑龍江 | 內(nèi)蒙古 |