Элементы массива в цикле, возвращающие случайные большие, иногда отрицательные числа - PullRequest
0 голосов
/ 14 апреля 2019

Я сканирую символы из входного файла и пытаюсь напечатать, сколько раз они встречаются в выходном файле.

Я пытался создать новый файловый поток исключительно для цикла, так как он использовался в предыдущем разделе кода. Я также попытался привести long long int к массиву и оператору печати, что дало мне только большие числа.

  FILE* input;
  FILE* output;
  input  = fopen("input.txt", "r");
  output = fopen("report.txt", "w");
  ...

  char letterTemp;
  float letterMax;
  int upperCounter = 0;
  int lowerCounter = 0;
  char alphaChars[26];
  int charCounter[26];

  for (char c = 'a'; c <= 'z'; ++c) {
    alphaChars[c - 'a'] = c; 
  }

  for (int i = 0; i < 26; i++) {
    fopen("input.txt", "r");

    while ((letterTemp = fgetc(input)) != EOF) {
      if (alphaChars[i] == letterTemp) {
        lowerCounter++;
        charCounter[i]++;
      }
      else if (toupper(alphaChars[i]) == letterTemp) {
        upperCounter++;
        charCounter[i]++;
      }
    }
    fclose(input);
  }
  letterMax = lowerCounter + upperCounter;

  fprintf(output, "LETTER STATISTICS\n\nCategory                How many in file    %% of all letters\n----------------------------------------------------------------------\nUppercase%31d%20.2f %%\nLowercase%31d%20.2f %%\n", upperCounter, 100 * upperCounter / letterMax, lowerCounter, 100 * lowerCounter / letterMax);

  for (int i = 0; i < 25; i++) {
    fprintf(output, "%c%39d%20.2f %%\n", alphaChars[i], charCounter[i], 100 * charCounter[i] / letterMax);
  }

Что дало бы мне ...

LETTER STATISTICS

Category                How many in file    % of all letters
----------------------------------------------------------------------
Uppercase                              9               12.16 %
Lowercase                             65               87.84 %
a                             2080375142         25393028.00 %
b                                  32766            44278.38 %
c                             2080375153         25393042.00 %
d                                  32767            44279.73 %
e                             -677299551         13371914.00 %
f                                  32734            44235.14 %
g                                      0                0.00 %
h                                      2                2.70 %
i                                      7                9.46 %
j                                      0                0.00 %
k                                      0                0.00 %
l                                      7                9.46 %
m                                      2                2.70 %
n                                      1                1.35 %
o                                      7                9.46 %
p                                      1                1.35 %
q                             2081514112         26932176.00 %
r                                  32770            44283.79 %
s                             -677300459         13370687.00 %
t                                  32735            44236.49 %
u                                      2                2.70 %
v                                      1                1.35 %
w                                      2                2.70 %
x                                      1                1.35 %
y                                      5                6.76 %

Что здесь происходит?

1 Ответ

1 голос
/ 15 апреля 2019

Поскольку в исходном сообщении используется toupper, используйте tolower islower и isupper, чтобы избежать многократного чтения файла и циклического повторения для совпадения символов.

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

int main ( ) {
    FILE* input = NULL;
    FILE* output = NULL;
    int letterTemp;
    float letterMax;
    int upperCounter = 0;
    int lowerCounter = 0;
    int charCounter[256] = { 0};//256 for all 8 bit values

    if ( NULL != ( input = fopen ( "input.txt", "r"))) {

        while ( ( letterTemp = fgetc ( input)) != EOF) {
            if ( islower ( letterTemp)) {//lower case
                lowerCounter++;
                charCounter[letterTemp]++;//increment count
            }
            if ( isupper ( letterTemp)) {//upper case
                upperCounter++;
                charCounter[tolower ( letterTemp)]++;//increment lower case count
            }
        }
        fclose ( input);
        letterMax = lowerCounter + upperCounter;

        if ( NULL != ( output = fopen ( "report.txt", "w"))) {
            fprintf ( output , "LETTER STATISTICS\n\n");
            fprintf ( output , "Category                How many in file    %% of all letters\n");
            fprintf ( output , "--------------------------------------------------------------\n");
            fprintf ( output , "Uppercase%31d%20.2f %%\nLowercase%31d%20.2f %%\n"
            , upperCounter
            , 100 * upperCounter / letterMax
            , lowerCounter
            , 100 * lowerCounter / letterMax);

            for (int i = 0; i < 256; i++) {
                if ( islower( i)) {//only print lower case values
                    fprintf ( output, "%c%39d%20.2f %%\n"
                    , i
                    , charCounter[i]
                    , 100 * charCounter[i] / letterMax);
                }
            }
            fclose ( output);
        }
        else {
            fprintf ( stderr, "could not open output file\n");
        }
    }
    else {
        fprintf ( stderr, "could not open input file\n");
    }
    return 0;
}
Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...