编程在一个已知的字符串中查找最长单词,假定字符串中只含字母和空格,用空格来分隔单词。

我没有用到数组, 因为我觉得数组太扯淡,定义数组需要知道数组的空间大小,对于随便一个字符串并不能准确定义数组空间来存放 空格数 或者 标 或者 单词.定义大了浪费内存定义小了不够;

如果按照题意用可以用二维数组轻松办到;  

还请大神教我不用数组可以办到的,使代码复用高点.我的不太好.    


char str[] = "wi xi huan ni";

        int k = -1,a = 0;

        unsigned int i = 0,b = 0 ;

        while (k == -1 || i < sizeof(str))  {

           k++;


    

           if (a < k){

    

               a = k;

                b = i;

    

            }

            if  (str[i] == ' ' || str[i] == '\0') {

                k = -1;

    

            }

            i++;

        }

        printf("最长的单词是:\n");

        for (int j = 0 ; j <= a; j++) {

            printf("%c",str[b - a +j]);

            

        }




评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值