Cout не печатает после чтения файлов - PullRequest
0 голосов
/ 06 декабря 2018

По какой-то причине мой кут не работает правильно.Я думаю, что это как-то связано с буфером, который нужно очистить.Я пытался добавить cout << flush после чтения файлов, но это не помогло.Единственное место, которое я печатаю, это main() в цикле for.Это вывод, который я получаю из этих отпечатков.

Aeberg
Aaren
Aaron
Full Name
 Aaron 

До и после Аарона есть пробел.Поэтому печатается только фамилия.

#include <iostream>
#include <fstream>
#include <queue>
#include <time.h>

using namespace std;

const int SIZE = 50000;

void initFirst(string first[]);
void initMiddle(string middle[]);
void initLast(string last[]);

int main()
{
  srand(time(NULL));
  ifstream in;
  ofstream out;

  string first[SIZE];
  string middle[SIZE];
  string last[SIZE];

  initFirst(first);
  initMiddle(middle);
  initLast(last);
  string x;

  for(int i = 0; i < 1; i++)
  {
    cout << first[i] << endl;
    cout << middle[i] << endl;
    cout << last[i] << endl;

    cout << "Full Name" << endl;
    cout << first[i] << " " << middle[i] << " " << last[i] << endl; // Isn't printing correctly here
  }

  return 1;
}

  void
initFirst(string first[])
{
  ifstream file("names.txt");
  string line;
  int counter = 0;

  if(file.is_open())
  {
    while(getline(file, line))
    {
      first[counter] = line;
      counter++;
    }
    file.close();
  }
  int left = SIZE - counter;
  int random[left];

  for(int i = 0; i < left; i++)
    random[i] = rand() % counter;

  for(int i = counter; i < SIZE; i++)
    first[i] = first[random[i-counter]];
}

void
initMiddle(string middle[])
{
  ifstream file("first-names.txt");
  string line;
  int counter = 0;

  if(file.is_open())
  {
    while(getline(file, line))
    {
      middle[counter] = line;
      counter++;
    }
    file.close();
  }

  int left = SIZE - counter;
  int random[left];

  for(int i = 0; i < left; i++)
    random[i] = rand() % counter;

  for(int i = counter; i < SIZE; i++)
    middle[i] = middle[random[i-counter]];
}

void
initLast(string last[])
{
  ifstream file("middle-names.txt");
  string line;
  int counter = 0;

  if(file.is_open())
  {
    while(getline(file, line))
    {
      last[counter] = line;
      counter++;
    }
    file.close();
  }

  int left = SIZE - counter;
  int random[left];

  for(int i = 0; i < left; i++)
    random[i] = rand() % counter;

  for(int i = counter; i < SIZE; i++)
    last[i] = last[random[i-counter]];
}

1 Ответ

0 голосов
/ 06 декабря 2018

Я бы посоветовал немного улучшить вашу программу.

  • вам не нужно три функции init, достаточно одной.Просто передайте параметр имени файла.
  • не используйте большие статические массивы, такие как string first[SIZE] - это приведет к переполнению стека.Вместо этого используйте векторы.
  • исправлены некоторые ошибки и не скомпилированы строки, такие как int random[left];
  • вам не нужен массив random
#include <cstdint>
#include <vector>
#include <string>
#include <fstream>
#include <iostream>
#include <time.h>

const size_t SIZE = 50000;
using strings = std::vector<std::string>; // 'array' of strings with dynamic size

void initFromFile(const std::string &fname, strings &arr)
{
    std::ifstream file(fname);
    std::string line;

    while(getline(file, line))
        arr.push_back(line);

    size_t n = arr.size();
    if(n == 0)
        return;
    for(auto i = 0; i < SIZE-n; i++)
        arr.push_back(arr[rand() % n]);
}


int main()
{
    using std::cout;
    using std::endl;
    srand(time(NULL));
    strings first, middle, last;

    initFromFile("names.txt", first);
    initFromFile("first-names.txt", middle);
    initFromFile("middle-names.txt", last);    

    for(auto i = 0U; i < first.size(); i++)
    {
        cout << first[i] << endl << middle[i] << endl << last[i] << endl;
        cout << "Full Name" << endl;
        cout << first[i] << " " << middle[i] << " " << last[i] << endl; 
    }
}
...