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

vector STL - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ работа с матрицей http://www.cyberforum.ru/cpp-beginners/thread215184.html
Пожалуйста помогите дописать правильно функцию int iz_faila(). Эта функция у меня читает матрицу из фаила, и выводит ее на экран. В добавок к этому необходимо, что бы программа подсчитала новую из той, которая была в фаиле, (по форме, как в функции void s_klav().) и ее вывела на экран. И что бы после этого, полученную матрицу, можно было записать в фаил, как в функции int masv_file(). Это у...
C++ Контейнерные классы Добрый вечер! Получил задание на редактирование параграфов из файла. Решил делать через контейнер вида map. Все считывается и выводится, но проблема в том, что выводится не по порядку. Например, сначала он выводит параграфа_1, а затем параграф_10,11,12 и как только дойдет до 19 выведет второй. Можно ли организовать в порядке возрастания? Если необходимо, могу прислать код. http://www.cyberforum.ru/cpp-beginners/thread215176.html
Классы + дружественные функции C++
Завтра экзамен а решить как не знаю. Тем более в классах я неоч петрю. кто откликнется с помощью скажу спасибо! Создать класс Time для работы со временем в формате «час:минута:секунда». Класс должен включать в себя не менее четырех функций инициализации: числами, строкой (например, «23:59:59»), секундами и временем. Обязательными операциями являются: вычисление разницы между двумя моментами...
Создание класса C++
Кто знает как реализовать эту прогу с помощью класса? Треугольник x1, y1, x2, y2, x3, y3 · печать (координат вершин) · площадь · определение типа треугольника · по умолчанию (0,0,0,1,1,0) · с параметрами (x1,y1,x2,y2,x3,y3) – с
C++ Посоветуйте с многофайловой разработкой программ http://www.cyberforum.ru/cpp-beginners/thread215166.html
Посоветуйте с программой. Экзамен завтра. 1) Описать аналоги библиотечных функций для работы со строками strlen(), strcat(), strcpy(), strcmp(). Протестировать функции в главной функции на примерах, введенных пользователем. Реализовать задачу с помощью многофайлового проекта: main.cpp – функция main(), mystring.cpp – реализация функций, mystring.h – прототипы функций.
C++ STL mismatch чтото я запутался в синтаксисе :( помогите заюзать mismatch, элементы не равны если различие более чем на Х. пс. если возможно организовать без pair? #include "stdafx.h" #include <iostream> #include <string> #include <algorithm> using namespace std; class mycl{ подробнее

Показать сообщение отдельно
IchMors
96 / 92 / 4
Регистрация: 16.05.2010
Сообщений: 307
20.12.2010, 00:30     vector STL
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
55
56
57
58
59
60
61
class data
{
public:
    char path[2];
    char net;
    char metric;
    int number; // для укаания строки таблици
};
 
class vertex
{
public:
    char name;
    vector<data> data_vertex;
};
 
 
//// выполнение copyTable(mass, table);
 
void ADD(char _mass[], vector<vertex> & _table, int position, int number, int _str)
{
    int temp = _table.size();
    if( temp <= position) cout << "Error\n";        // вот здесь и ошибка ((((
        _table[position].name = _mass[0];      //
        _table[position].data_vertex.reserve(1);
        _table[position].data_vertex[number].path[0] = _mass[0];
        _table[position].data_vertex[number].path[1] = _mass[1];
        _table[position].data_vertex[number].net = _mass[2];
        _table[position].data_vertex[number].metric = _mass[3];
        _table[position].data_vertex[number].number = _str;
}
 
char last(vector<vertex> _table)
{
    int a;
    a = _table.size() - 1;
    return _table[a].name;
}
 
void copyTable(char _mass[], vector<vertex> & _table)
{
    if(_table.empty())
    {
        _table.reserve(1);
        ADD(_mass, _table, 0, 0, 1);
    }
    else
    {
        int posit = int(last( _table)) - 49;
        if(last( _table)==_mass[0])
        {
            _table[posit].data_vertex.reserve(1);
            ADD(_mass, _table, posit, _table[posit].data_vertex.size() - 1, 0);
        }
        else
        {
            _table.reserve(1);
            ADD(_mass, _table, posit, 0, 0);
        }
    }//end first else
}
при добавлении нового/первого элемента вылетает программа. резервирую память под новый обьект _table.reserve(1); , но баг в том, что при индексировании идет проверка при помощи .size() и жалуется на то что индекс обращения к обьекту меньше чем сам размер вектора (а пытаюсь добавить в новь выделенную память). Подскажите пожалуйста где я ошибся и как обойти .size()

Добавлено через 40 секунд
вылетает в 23, 24 строках
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 17:07. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru