Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.72/29: Рейтинг темы: голосов - 29, средняя оценка - 4.72
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 7

Чтение графа из файла

13.01.2015, 21:38. Показов 5844. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Имеется файл, состоящий из двух секций.

В первой находится v линий с двумя дробными числами, означающими координаты х и у последующих вершин.

Во второй секции находится e линий с двумя целыми числами и одной дробной означающими: номер начальной вершины, конечной и вес ребра.
Задача состоит в том, чтобы написать функцию, которая сама определит "переход" между секциями и считает координаты из первой секции файла в массив вершин и из второй в массив координат соответственно.

Так выглядит файл.
Кликните здесь для просмотра всего текста
0.2 0.1
1.2 0.2
1.2 1.1
0.2 1.1
0.3 1.2
0.4 2.1
0 1 12.3
1 2 10
2 3 2.4
3 1 1.1
3 4 5.0
5 4 5.0
4 5 5.4


Структура для вершин.
C++
1
2
3
4
struct vertex
{
    double x, y;
};
Структура для ребер.
C++
1
2
3
4
5
struct edge
{
    int start, destination;
    double wieght;
};
Я планировал создать 2 контейнера.
C++
1
2
    vector<vertex> v;
    vector<edge> e;
Каждая новая строка записывалась бы в отдельную ячейку.

Собственно, вопрос. Как заставить программу при чтении файла учитывать новую строку и как определить переход из первой секции во вторую?
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
13.01.2015, 21:38
Ответы с готовыми решениями:

Переделать в коде чтение из файла в чтение с клавиатуры
Переделайте что бы текст считывался с клавиатуры, а не с файла! Буду благодарен за помощь! //файл должен начинаться со слова, между...

Чтение из файла. Повторное чтение файла
Добрый день. Необходимо реализовать в программе функцию повторного чтения данных из файла, в случае некорректного ввода их в оный. Вот...

Импорт графа из файла
Добрый день! Задача по графам. Вот так реализована функция вывода графа на экран: void Graph::display() { for (int i...

2
DU
1500 / 1146 / 165
Регистрация: 05.12.2011
Сообщений: 2,279
13.01.2015, 21:49
переход можно определить при парсе каждой строки. если скажем три пробела - значит строка относится ко второй секции, иначе - к первой. примерно так:

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
void ProcessLine(const std::string& line, std::vector<vertex>& v, std::vector<edge>& e)
{
  // тут парсим строку и создаем из нее либо vertex, либо edge и засовываем созданное в
  // соответствующий контейнер
}
 
void ReadGraph(const std::string& filePath, std::vector<vertex>& v, std::vector<edge>& e)
{
  std::ifstream file(filePath);
  while (file)
  {
     std::string line;
     std::getline(file, line);
     ProcessLine(line, v, e);
  }
}
 
int main()
{
  std::vector<vertex> v;
  std::vector<edge> e;
  ReadGraph("path_to_graph_file", v, e);
 
  // тут имеем заполненные вектора.
 
  return 0;
}
1
0 / 0 / 0
Регистрация: 16.11.2013
Сообщений: 7
13.01.2015, 21:53  [ТС]
Спасибо, идея нравится, сейчас попробую.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
13.01.2015, 21:53
Помогаю со студенческими работами здесь

Преобразование текстового файла в двоичный и чтение исходных данных из двоичного файла.
#include&lt;iostream&gt; #include&lt;fstream&gt; #include&lt;locale.h&gt; #include&lt;iomanip&gt; #include &lt;cstdlib&gt; using namespace std; struct...

Чтение нескольких структур и одной переменной из бинарного файла. Формат файла имеется
Формат файла состоит из 3 структур и одной переменной. Подробное описание формата во вложении, просьба посмотреть его. У меня возникла...

Как может корректно выполняющийся оператор >> (чтение из текстового файла) негативно влиять на открытие другого файла?
Друзья! Создадим два текстовых файла, f_0.txt и f_1.txt и что-нибудь в них запизаем, например в первый запихаем 1234 а во второй 5678 и...

Чтение файла с несколькими знаками конца файла
В файле несколько раз встречается ноль, и ни как не получается прочитать его полностью. Как можно решить данную проблему ?

Нужна помощь в сохранении графа в файл и его загрузки из файла
Вот код. #include &lt;iostream&gt; #include &lt;conio.h&gt; using namespace std; /////////////////////////////////////////////////////////// ...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru