Chinaunix首页 | 论坛 | 博客
  • 博客访问: 428092
  • 博文数量: 71
  • 博客积分: 26
  • 博客等级: 民兵
  • 技术积分: 1246
  • 用 户 组: 普通用户
  • 注册时间: 2012-07-23 14:46
个人简介

linux --- 一切皆文件

文章分类

全部博文(71)

文章存档

2021年(1)

2019年(2)

2018年(4)

2017年(7)

2016年(11)

2015年(1)

2014年(2)

2013年(33)

2012年(10)

分类: C/C++

2013-05-15 23:23:46

统计单词长度,输出直方图.输出垂直直方图的方法和像素扫描一样,可以计算出最高的那行,然后一行一行的输出

#include

#define IN 1
#define OUT 0
#define MAXLEN 20

int word[MAXLEN];

int main(void)
{
    int c,i;
    int stat;
    int wc,maxvalue,overload;
    stat = OUT;
    overload = 0;


    for(i = 0;i < MAXLEN;i ++)
        word[i] = 0;


    while((c = getchar()) != EOF){
        if(c == ' ' || c == '\n' || c == '\t'){
            stat = OUT;
            if(wc > 0){
                if(wc < MAXLEN){
                //printf("wc %d \n",wc);
                word[wc]++;
            }else{
            overload ++;
            }
    }
        wc = 0;
    }else if(stat == OUT){
        stat = IN;
        wc = 1;
    }else{
        wc ++;
    }
}

    maxvalue = 0;
    for(i = 0;i < MAXLEN;i ++){
        if(word[i] > maxvalue){    
            maxvalue = word[i];
        }
    }
    int j;
    for(i = maxvalue;i > 0;i --){
        printf("%d |",i);
        for(j = 0;j < MAXLEN;j ++){
            if(word[j] >= i)
                printf("*   ");
            else
                printf("    ");
      }
        printf("\n");    
    }

    printf("   ------------------------------------------------------------------------------------\n");
    printf("    ");
    for(i = 0;i < MAXLEN;i ++){
        printf("%d   ",i);
    }
    printf("\n");

    printf("the overload word  %d  \n",overload);
    return 0;
}



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