Программа всегда производит одно и то же значение? - PullRequest
0 голосов
/ 21 сентября 2011

цель моей программы - записать числа 1 - 1 000 000 в текстовый файл, сгенерировать случайное число от 1 до 1 000 000, найти эту строку в текстовом файле, взять значение и возвести его в квадрат (это просто для меня это упражнение не имеет практического применения) Проблема заключается в том, что всякий раз, когда я запускаю его, значение остается неизменным, но функция rand() помечается time(0). Я подозреваю, что это мусорная ценность, но я не знаю, откуда она берется (у меня нет опыта работы с GDB или другими автономными отладчиками). Вот мой исходный код:

#include <fstream>
#include <ctime>
#include <iostream>
#include <string>
#include <cstdlib>
using namespace std;

int main(int argc, char** argv){
    ofstream file("log.txt", ios::app);
    ofstream programLog("programlog.dat", ios::app);
    cout << "Test Start" << endl;
    programLog << "Test Start" << endl;
    cout << "Log file created" << endl;
    programLog << "Log file created" << endl;
    ifstream readFile("log.txt");
    int foundNum;
    std::string line = "";
    unsigned int loopCount = 1000000;
    unsigned int numToSearch;
    const unsigned short min = 1;
    const int max = 1000000;
    unsigned int randomLine = 0;

    for(int i = 0; i <= loopCount; i++){
        file << i << endl;
    }

    //select random line
    srand((unsigned)time(0));

    while(!(randomLine > min) && !(randomLine < max)){
        randomLine = (unsigned)rand();
        programLog << randomLine;
        int newlines = 0;
        //size_t found;
        while(getline(readFile, line)){
            if(line.find("\n") != string::npos)
                newlines++;
            if(newlines == randomLine)
                numToSearch = atoi(line.c_str());
        }

    }

    programLog << "Random line selected" << endl;

    //read line
    while(std::getline(readFile,line)){
        if(atoi(line.c_str()) == numToSearch){
            foundNum = numToSearch;
            break;
        }
        else
            continue;
    }

    //square it
    const unsigned int squared = foundNum*foundNum;

    programLog << squared;
    readFile.close(); //end read
    file.close(); //end log
    programLog.close(); //end programlog
    return 0;
}

Ответы [ 2 ]

2 голосов
/ 21 сентября 2011

Вы никогда не входите в цикл while, поскольку используете:

while(!(randomLine > min) && !(randomLine < max))

, в то время как сразу оценивается как ложное.Вы должны использовать:

while(randomLine < min || randomLine > max)

Кроме того, почему все ваши переменные имеют разные типы?Это может привести к непреднамеренным ошибкам.Вы должны изменить их, чтобы иметь тот же тип.

1 голос
/ 21 сентября 2011

randomLine инициализируется равным 0, и все еще имеет это значение, когда достигает значения while, поэтому тело цикла никогда не выполняется.

...