2016-04-27 16 views
1

私は、文字、単語、行をCの段落を標準入力から数えようとしています。文字、単語、行Cの段落を集める

何かが動作していないと私はなぜわからない。

#include <stdio.h> 

int main(int argc, char const *argv[]) 
{ 
    int pCount=0, parCount=0, cCount=0, lCount=0; 
    double prom=0; 
    char c; 
    int newln_cnt=0; 
    while ((c=getchar())!=EOF){ 
     cCount++; 
     switch (c) 
     { 
      case '\n': 
       newln_cnt++; 
       lCount++; 
       if (newln_cnt == 2) 
       { 
        parCount++; 
        newln_cnt = 0; 
       } 
       break; 
      case ' ': 
       pCount++; 
       break; 
     }    
    } 
    prom = (cCount/pCount); 
    printf("Total caracteres: %d \n", cCount); 
    printf("Cantidad palabras: %d \n", pCount); 
    printf("Cantidad líneas: %d \n", lCount); 
    printf("Cantidad párrafos: %d \n", parCount); 
    printf("Promedio longitud palabra: %f \n", prom); 
    return 0; 
} 

これは、文字(あまり表示されません)とちょっと違います。残りはすべて悪いです。

入力:

Oid, mortales, el grito sagrado: 
"Libertad, libertad, libertad!" 

Oid el ruido de rotas cadenas, 
ved en trono a la noble igualdad. 

Ya su trono dignisimo abrieron 
las Provincias Unidas del Sud 

y los libres del mundo responden: 
"Al gran pueblo argentino, salud! 
Al gran pueblo argentino, salud!" 

Y los libres del mundo responden: 
"Al gran pueblo argentino, salud!" 

Sean eternos los laureles 
que supimos conseguir, 
que supimos conseguir. 

Coronados de gloria vivamos... 
o juremos con gloria morir!, 
o juremos con gloria morir!, 

o juremos con gloria morir! 

期待出力リレー:

Total caracteres: 558 
Cantidad palabras: 87 
Cantidad líneas: 25 
Cantidad párrafos: 8 
Promedio longitud palabra: 4.966 

私の出力に含ま:プログラムは、文字、単語、行や段落の数をカウント

Total caracteres: 557 
Cantidad palabras: 69 
Cantidad líneas: 24 
Cantidad párrafos: 12 
Promedio longitud palabra: 8.000 

(2人の共同nsecutive '\ n')。平均単語長。

+1

を 'char型のC;' 'int型のCでなければなりません;'。 –

+2

あなたは 'cCount'をインクリメントしません。 'pCount'は実際には単語の数と全く同じではないスペースの数です。スペースを入れずに3行を入力すると、 'pcount'はどうなるでしょうか? –

+0

あなたの質問にはいくつかの進歩がありますが、入力サンプルはデバッグには余りにも長すぎます。 –

答えて

2

それぞれのカウント条件が間違っています。以下のような
修正は次のとおりです。

#include <stdio.h> 
#include <ctype.h> 

int main(void){ 
    int pCount=0, parCount=0, cCount=0, lCount=0;//word, paragraph, character, line 
    int abCount = 0;//alphabet 
    double prom=0; 
    int c;//It should be int. 
    char pprev = '\n', prev = '\n'; 

    while ((c=getchar())!=EOF){ 
     ++cCount; 
     if(isalpha(c)) 
      ++abCount; 
     if(isspace(c)){ 
      if(c == '\n'){ 
       ++lCount; 
      } 
     } else if(isspace(prev)){//isspace(prev) && !isspace(c) : edge of top of word 
      ++pCount; 
      if(pprev == '\n' && prev == '\n'){//edge of top of paragraph 
       ++parCount; 
      } 
     } 
     pprev = prev; 
     prev = c; 
    } 
    if(prev != '\n'){//If the file is not terminated by newline 
     ++lCount; 
    } 

    prom = (double)abCount/pCount;//(cCount - spcCount - punctCount)/pCount 
    printf("Total caracteres: %d \n", cCount); 
    printf("Cantidad palabras: %d \n", pCount); 
    printf("Cantidad lineas: %d \n", lCount); 
    printf("Cantidad parrafos: %d \n", parCount); 
    printf("Promedio longitud palabra: %.3f \n", prom); 
    return 0; 
} 
+0

厳密に言えば、区切り記号を削除するには単語の数でなければなりません。 – BLUEPIXY

-2

それはなぜなら型変換エラーのコンパイルされませんでしたが、あなたはすべてのためにフロートを使用することができ、それがコンパイルされます:

#include <stdio.h> 

int main(int argc, char const *argv[]) 
{ 
    double pCount=0, parCount=0, cCount=0, lCount=0; 
    double prom=0; 
    char c; 
    int newln_cnt=0; 
    while ((c=getchar())!=EOF){ 
     switch (c) 
     { 
      case '\n': 
       newln_cnt++; 
       lCount++; 
       if (newln_cnt == 2) 
       { 
        parCount++; 
        newln_cnt = 0; 
       } 
       break; 
      case ' ': 
       pCount++; 
       break; 
     }    
    } 
    prom = (cCount/pCount); 
    printf("Total caracteres: %f \n", cCount); 
    printf("Cantidad palabras: %f \n", pCount); 
    printf("Cantidad líneas: %f \n", lCount); 
    printf("Cantidad párrafos: %f \n", parCount); 
    printf("Promedio longitud palabra: %f \n", prom); 
    return 0; 
} 

今、プログラムがコンパイルされることを、あなたはあなたのために最適ですどんなタイプに調整することができますあなた自身のタイプを持っているかもしれません。

プログラムのように動作する有名なプログラムは、単語数がwcで、標準のUnixライブラリの一部です。

+2

ここで浮動小数点型を使うのは整数より優れているのはなぜですか? – dreamlax

+0

@dreamlax _ "Promedio longitudinal palabra"は_average_ –

+1

を意味します@ Programmer400 _average word length_ –

0

私はあなたのコード内でいくつかの問題を参照してください。

  1. 段落カウント:読み取り文字は\nの異なる場合は、0にnewln_cntを設定しないでください。これにより、2つの文章が1つずつカウントされます。\nが読み込まれます。

  2. スペース数:' '文字しか考慮していない場合、空白以外の空白文字は見当たりません。 isspace()の機能を使用することを検討してください。

  3. 平均線の長さは:

    prom = (float)cCount/(flao)pCount; 
    

私のアドバイス:あなたはキャストを検討し、フロートを取得するには2つの整数を分割短いテキスト(1行に3ワード、5線)とAで開始デバッガ。

関連する問題