Форум программистов, компьютерный форум CyberForum.ru

Заменить считывание с клавиатуры на считывание из файла - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Подсчитать количество слов, начинающихся с буквы 'а' http://www.cyberforum.ru/cpp-beginners/thread897481.html
Дано предложение-строка. Подсчитать количество слов, начинающихся с буквы 'а'.
C++ Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с отрицательными элем Написать функцию проверяющую есть ли отрицательные элементы в указанной строке двумерного массива. Удалить из массива все строки с отрицательными элементами, удаленная строка заполняется 0 и переносится в конец массива. Найти минимальный из неповторяющихся элементов двумерного массива Добавлено через 8 минут ......... http://www.cyberforum.ru/cpp-beginners/thread897474.html
Сформировать строки таким образов, что бы первой была самая короткая строка, а последней самая длинная C++
задан строка. сформировать строки таким образов что бы первой была самая короткая строка а последней самая длинная (все остальные строки остаются как были) например так: (исходный текст: "жили у бабуси два веселых гуся" --> сформированный текст: " у жили бабуси два гуся веселых")
C++ sortirovka slov
задан текст. выполнить сортировку слов расположив их в порядке увеличения букв. (пример: qqqq ssssssss dfghdfagkhbbgfd kjdfkgkdnlglhmeurtiuerbgn)
C++ Сортировка слиянием http://www.cyberforum.ru/cpp-beginners/thread897451.html
Объясните пожалуйста как сделать рекурсивную сортировку слиянием списка. Список имеет такие элементы struct List { int data; List* next; }; Единственное, что понял,надо рекурсивно делить списки по палам, а вот когда сортировать не знаю.
C++ Проблемы с VS 2012 Имеется код, он прекрасно работает в Visual Studio 2008, но при компиляции в 2012 версии выдает такую вот ошибку. Как от нее можно отделаться и вообще отделаться от ошибок 2012 версии :) #define _CRT_SECURE_NO_WARNINGS #include <stdio.h> #include <iostream> #include <conio.h> using namespace std; int main(int argc, char* argv) подробнее

Показать сообщение отдельно
Lapidos
0 / 0 / 0
Регистрация: 13.12.2012
Сообщений: 43
10.06.2013, 16:01     Заменить считывание с клавиатуры на считывание из файла
Помогите пожалуйста, ни разу не работал со считыванием из файла поэтому не понимаю как и что делать. Почитал в интернете, попробовал, не получается, а очень надо, зачет на кону.

Требуется заменить в коде все считывание с клавиатуры на считывание из файла.
Допустим файл test.txt будет выглядеть так:

5
0 1 1 0 0
1 0 1 1 0
1 1 0 1 0
0 1 1 0 1
0 0 0 1 0
1
5

Вот код:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
#include <iostream>
#include <vector>
#include <queue>
#include <limits>
 
using namespace std;
 
const int infinity = numeric_limits <int>::max();
 
typedef vector <int> vi;
typedef vector <vector <int> > vvi;
 
int main(int argc, char* argv[])
{
    locale::global(locale(""));
    cout << "Введите количество вершин" << endl;
    int n;
    cin >> n;
    vvi v (n, vi(n, 0)); //матрица смежности
    cout << "Введите матрицу" << endl;
    for (int i = 0; i < n; i++)
        for (int j = 0; j < n; j++)
            cin >> v[i][j];
    
    int start;
    int finish;
    cout << "Введите начальную вершину" << endl;
    cin  >> start;
    cout << "Введите конечную вершину" << endl;
    cin  >> finish;
 
    vi d(n, infinity);   //массив длин
    d[start-1] = 0;
 
    queue <int> q;
    q.push(start-1);
 
    while (!q.empty())
    {
        int now = q.front();
        q.pop();
        for (int i = 0; i < n; i++)
            if (v[now][i] != 0 && d[now] + v[now][i] < d[i])
            {
                d[i] = d[now] + v[now][i];
                q.push(i);
            }
    }
 
    cout << "Длинна кратчайшего пути равна = "
         << d[finish-1] << endl;
    cin.get();cin.get();
    return 0;
}
Сама программа считает минимальное расстояние в графе от одной вершины до другой с помощью волнового алгоритма. Помогите пожалуйста!
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:05. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru