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

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

13.01.2015, 21:38. Показов 5885. Ответов 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
Ответ Создать тему
Новые блоги и статьи
Идея фильтра интернета (сервер = слой+фильтр).
Hrethgir 31.03.2026
Суть идеи заключается в том, чтобы запустить свой сервер, о чём я если честно мечтал давно и давно приобрёл книгу как это сделать. Но не было причин его запускать. Очумелые учёные напечатали на. . .
Модель здравосоХранения 6. ESG-повестка и устойчивое развитие; углублённый анализ кадрового бренда
anaschu 31.03.2026
В прикрепленном документе раздумья о том, как можно поменять модель в будущем
10 пpимет, которые всегда сбываются
Maks 31.03.2026
1. Чтобы, наконец, пришла маршрутка, надо закурить. Если сигарета последняя, маршрутка придет еще до второй затяжки даже вопреки расписанию. 2. Нaдоели зима и снег? Не надо переезжать. Достаточно. . .
Перемещение выделенных строк ТЧ из одного документа в другой
Maks 31.03.2026
Реализация из решения ниже выполнена на примере нетипового документа "ВыдачаОборудованияНаСпецтехнику" с единственной табличной частью "ОборудованиеИКомплектующие" разработанного в конфигурации КА2. . . .
Functional First Web Framework Suave
DevAlt 30.03.2026
Sauve. IO Апнулись до NET10. Из зависимостей один пакет, работает одинаково хорошо как в режиме проекта так и в интерактивном режиме. из сложностей - чисто функциональный подход. Решил. . .
Автоматическое создание документа при проведении другого документа
Maks 29.03.2026
Реализация из решения ниже выполнена на нетиповых документах, разработанных в конфигурации КА2. Есть нетиповой документ "ЗаявкаНаРемонтСпецтехники" и нетиповой документ "ПланированиеСпецтехники". В. . .
Настройка движения справочника по регистру сведений
Maks 29.03.2026
Решение ниже реализовано на примере нетипового справочника "ТарифыМобильнойСвязи" разработанного в конфигурации КА2, с целью учета корпоративной мобильной связи в коммерческом предприятии. . . .
Автозаполнение реквизита при выборе элемента справочника
Maks 27.03.2026
Программный код из решения ниже на примере нетипового документа "ЗаявкаНаРемонтСпецтехники" разработанного в конфигурации КА2. При выборе "Спецтехники" (Тип Справочник. Спецтехника), заполняется. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru