文章详情

  • 游戏榜单
  • 软件榜单
关闭导航
热搜榜
热门下载
热门标签
php爱好者> php文档><font color='#FF0000'>C程序习题-找出一行字符中..

<font color='#FF0000'>C程序习题-找出一行字符中..

时间:2010-08-09  来源:chengxiaopeng

   写一函数,输入一行字符,将此字符中最长的单词输出。    我们知道,当出现空格的时候。也就表示一个单词已经结束。当出现'.'或者';'代表一句话已经结束了。因此我们可以使用变量记录一个单词出现的开始位置和结束位置。找出单词最大的开始和结束处。重新输出即可。代码如下(经测试,有时候会出错,以后想到好的办法,再修改):  

#include <stdio.h>
void printlongdanci(char[]);
int is_char(char);
int main (int argc, char *argv[])
{
    char ch1[100];
    printf("please input 1 line string:\n");
    gets(ch1);
    printf("the long danci is :");
    printlongdanci(ch1);
    system("pause");
    return 0;
}

void printlongdanci(char ch[])
{
     int i,j = 0,k = -2,temp_begin = 0,temp_end = 0;
     int begin = 0,end;
     int max = 0;
     char c;
     int str_len = strlen(ch);
     for (i = 0; i< str_len; i++)
     {
         c = ch[i];
         if (is_char(c))
         {
            j++;
         }
         else if (' ' == c)
         {
             
              if (j > max)
              {
                 max =j;
                 end = i - 1;
                 begin = temp_begin;
              }
              
              temp_begin = i + 1;
              temp_end = i -1;
              
              j = 0;
         }
         else if ((c == '.' || c == ';') && ((ch[i+1]) == '\0'))
         {
             if (j > max) //并且此字符后面不能含有字符。则认为这个一个单词。

              {
                 max =j;
                 end = i - 1;
                 begin = temp_begin;
              }
              
              temp_begin = i + 1;
              temp_end = i -1;
              
              j = 0;
         }
         else
         {
             ;
         }
     }
     
     for (i = begin; i <= end ; i++)
     {
         printf("%c",ch[i]);
     }
}

int is_char(char c)
{
    int i = 0;
    if ((c >= 'a' && c <='z') ||(c >= 'A' && c <= 'Z'))
    {
       i = 1;
    }
    return i;
}


相关阅读 更多 +
排行榜 更多 +
辰域智控app

辰域智控app

系统工具 下载
网医联盟app

网医联盟app

运动健身 下载
汇丰汇选App

汇丰汇选App

金融理财 下载