| 网站首页 | 业界新闻 | 小组 | 威客 | 人才 | 下载频道 | 博客 | 代码贴 | 在线编程 | 编程论坛
欢迎加入我们,一同切磋技术
用户名:   
 
密 码:  
共有 817 人关注过本帖
标题:用函数调用求最长单词并输出
只看楼主 加入收藏
大学的守望者
Rank: 1
等 级:新手上路
帖 子:17
专家分:2
注 册:2011-4-16
结帖率:33.33%
收藏
已结贴  问题点数:10 回复次数:5 
用函数调用求最长单词并输出
有一串字符,以空格表示单词的结束,求字符串中的最长单词并输出
搜索更多相关主题的帖子: 字符串 
2011-05-19 22:33
ansic
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:恍惚窈冥
等 级:城市猎人
帖 子:1543
专家分:5367
注 册:2011-2-15
收藏
得分:3 
程序代码:
root@~ #cat zc.c
#include <stdio.h>
#include <string.h>
#define N 100

int main (void) {

        char str[N][80];
        int i;
        void longstr(char str[][80]);

        for(i=0;i<N;i++) {
                scanf("%s",str[i]);
        }

        printf("Long string is: ");
        longstr(str);

        return 0;

}
void longstr(char str[][80]) {
        int i,j,maxlen=0;
        for(i=0;i<N;i++) {
                if(strlen(str[i])>maxlen) {
                        maxlen=strlen(str[i]);
                        j=i;
                }
        }
        printf("%s\n",str[j]);
}
root@~ #./zc
asdf sdf sdfsdfsdfsdfsdfsdfsdf sdfsd sdf
Long string is: sdfsdfsdfsdfsdfsdfsdf
root@~ #./zc
a ab abc abcde abcdefg
Long string is: abcdefg
root@~ #


[ 本帖最后由 ansic 于 2011-5-19 23:09 编辑 ]

善人者,不善人之师;不善人者,善人之资。不贵其师,不爱其资,虽智大迷。
2011-05-19 22:54
大学的守望者
Rank: 1
等 级:新手上路
帖 子:17
专家分:2
注 册:2011-4-16
收藏
得分:0 
回复 2楼 ansic
只有一串字符,里面有很多单词,求其中最长单词,要调用函数做
2011-05-19 23:05
mindme
Rank: 1
等 级:新手上路
帖 子:4
专家分:2
注 册:2011-4-18
收藏
得分:3 
这个论坛里好多课后题,
2011-05-19 23:19
lcddhr
Rank: 2
等 级:论坛游民
帖 子:25
专家分:29
注 册:2011-5-18
收藏
得分:3 
#include <stdio.h>
#include <string.h>

void find(char s[80],int n)
{
   int i,j=0,k=0,max,num=0;

   char s1[10][20];


   for(i=0;i<n;i++)   //计算你的字符串里面有多少个空格,num用来计数。

    {
      if(s[i]==' ')
      num++;
    }



  for(i=0;i<num;i++)   //计算出的空格数,说明你的字符串里面有num+1个单词数,

   {
     while(s[j]!=' ')
       {
        s1[i][k]=s[j];  //用二维数组来存放单词,当i=0时存放的是第一个单词,把一维数组的字符赋值给二维数组,以此类推。
        j++;
        k++;
        }
      j++;
      k=0;   //k值回到二维数组的第0列
   }

   max=0;

   for(i=0;i<num;i++)    //找出二维数组中单词最长的的地址
   if(strlen(s1[max])<strlen(s1[i]))
     max=i;


    printf("%s",s1[max]);

    }


void main()
{
  char s[80];
  gets(s);
  find(s,strlen(s));

 }
2011-05-20 00:19
lz1091914999
Rank: 14Rank: 14Rank: 14Rank: 14
来 自:四川
等 级:贵宾
威 望:37
帖 子:2011
专家分:5959
注 册:2010-11-1
收藏
得分:3 
程序代码:
#include <stdio.h>
#define MAXSIZE 81

int strlen(char * str) {
    int count = 0;
    while(*str++) count++;
    return count;
}

void strcpy(char * to, const char * from, int size) {
    int i = 0;
    while(i < size) {
        to[i] = from[i];
        i++;
    }
    to[i] = '\0';
}

int main(void) {
    char * str = "a bc def ghij klmno pqrstu vwxyz aaaaaaaaaaaa";
    int count = 0, maxLength = 0, maxIndex, i;
    char maxString[MAXSIZE];
    for(i = 0; i < strlen(str) + 1; i++) {
        if(str[i] != ' '  && str[i] != '\0')
            count++;
        else {
            if(maxLength < count) {
                maxLength = count;
                maxIndex = i - count;
            }
            count = 0;
        }
    }
    strcpy(maxString, str + maxIndex, maxLength);
    printf("%s\n", maxString);
    return 0;
}
图片附件: 游客没有浏览图片的权限,请 登录注册

My life is brilliant
2011-05-20 09:07
快速回复:用函数调用求最长单词并输出
数据加载中...
 
   



关于我们 | 广告合作 | 编程中国 | 清除Cookies | TOP | 手机版

编程中国 版权所有,并保留所有权利。
Powered by Discuz, Processed in 0.020714 second(s), 9 queries.
Copyright©2004-2024, BCCN.NET, All Rights Reserved