Chinaunix首页 | 论坛 | 博客
  • 博客访问: 2539912
  • 博文数量: 308
  • 博客积分: 5547
  • 博客等级: 大校
  • 技术积分: 3782
  • 用 户 组: 普通用户
  • 注册时间: 2009-11-24 09:47
个人简介

hello world.

文章分类

全部博文(308)

分类: C/C++

2010-08-09 18:58:03

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

#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;
}


阅读(1590) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~