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

Описать класс *предметный указатель* - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Запрограммировать связный список, в котором информация о книгах сортируется по убыванию стоимости http://www.cyberforum.ru/cpp-beginners/thread862702.html
Пожалуйста помогите, очень надо(((( Запрограммировать связный список, в котором информация о книгах сортируется по убыванию стоимости. При этом нужно выделять память динамически и обработку списков следует выполнить на основе базовых алгоритмов: поиск по списку, вставка элемента в список, удаление элемента из списка, удаление всего списка. При объявлении списков выполнить комментирование...
C++ Математическая формулировка Доброго времени дня всем. У меня возникла проблема. Значит сделал я программу по следующему условию: Разработать программу, реализующую алгоритм очереди (20 элементов). Задача решается в двух вариантах: статическом (на основе массива структур) и динамическом. Реализовать алгоритм кольцевой очереди на основе динамического списка. В качестве элемента очереди выбрать структуру, соответствующую... http://www.cyberforum.ru/cpp-beginners/thread862697.html
получить гистограмму (столбчатую диаграмму) длин всех слов файла C++
Добрый день,помогите пожалуйста доработать программу. Нужно получить гистограмму (столбчатую диаграмму) длин всех слов файла #include <iostream> #include <sstream> #include <vector> #include <fstream> #include <iomanip> using namespace std; int _tmain(int argc, _TCHAR* argv) {
C++ Программа выводит лишнюю информацию
Выводит лишнюю информацию,программа проходит и в конце выдает результат и лишнее,не пойму в чем фокус должна выдавать один из вариантов,а не два вот сама программа: #include <iostream> using namespace std; int main() {int cash; cout<<"Vvedite kolicestvo cash "; cin>>cash;
C++ Оформить в виде функции на C++ решение задачи http://www.cyberforum.ru/cpp-beginners/thread862676.html
Добрый вечер! Помогите решить задачу на C++. (Среда компилирования: Turbo C++ в DOS BOX) {b}_{i}= \prod_{j}^{i}{a}_{j} где i=1,2,3...,n P.S. Если можно, с небольшим объяснением. Заранее благодарен.
C++ Пирамидвльная сортировка Здрваствуйте помогите разобраться в пирамидвльной сортировке и найти ошибку необходимо отсортировать структуру взятую из файла по номеру ''nom'' вот мой набросок #include<iostream> #include<conio.h> #include<math.h> #include<string.h> #include<fstream> #include<iomanip> подробнее

Показать сообщение отдельно
pashazt
0 / 0 / 0
Регистрация: 18.04.2013
Сообщений: 42
12.05.2013, 19:03  [ТС]     Описать класс *предметный указатель*
Описать клас *предметный указатель*. Каждый компонент указателя содержит слово и номер страницы, на которых ето слово встречаеться. Количество номеров страницы, которые относяться к одному слову, от одного до десяти. Предусмотреть возможность формирования указателя с клавиатуры и с файла, итог указателя, итог номеров страниц для заданого слова, удаление элемента с указателя.

Написал с помощью вектора, но функции поиска и удаления не работают. Функция поиска выводит числа для всех слов, а функция удаления вовсе не компилируеться(текст ошибки написал в коде). HELP!

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
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
#include <iostream>
#include <list>
#include <conio.h>
#include <vector>
#include <algorithm>
 
using namespace std;
 
class Work
{
public:
    char name[30];
    int number[10];
    int CountNumber();
    void input(int n);
    void output(int n);
    void search(int n);
    void deletetask(int n);
    void menu(int n);
};
 
vector<Work> v(3);
 
void Work :: input(int n)
{
    
    int j = 10;
    
    cout<<"Формирование предметного указателя"<<endl;
 
 
    
    for (int i = 0; i < v.size(); i++)
    {
        cout << " Введите слово № "<< i+1 <<" : ";
        cin >> v[i].name;
 
        cout << " Введите номера страницы: ";
        for (int j = 0; j < 3; j++)
        {
            cin >> v[i].number[j];
        }
        
    }
    cout<<"Формирование завершено\n";
}
 
void Work::output(int n)
{
    
    cout<<"Вывод предметного указателя :"<<endl;
        for (int i = 0; i < v.size(); i++)
        {
            cout<<"Слово: "<<v[i].name<<endl;
            cout << "Номера страниц : ";
            for (int j = 0; j < 3; j++)
            {
                 cout << " "<< v[i].number[j];
                
            }
            cout << "" << endl;
        }
}
 
void Work::search(int n)
{
    char NameSearch[30];
 
    cout << "Введите искомое слово : ";
    cin >> NameSearch;
 
    for (int i = 0; i < v.size(); i++)
    {
        if (strcmp(v[i].name, NameSearch) == 0)
            cout << "Слово: "<< v[i].name << endl;
            cout << "Номера страниц : ";
            cout << " "<< v[i].number[3];
 
            for (int j = 0; j < 3; j++)
            {
                 cout << " "<< v[i].number[j];
            }
    }
}
  
void Work::deletetask(int n)
{
    char DeleteName[30];
 
    cout << "Введите слово, которое хотите удалить : ";
    cin >> DeleteName;
 
    for (int i = 0; i < v.size(); i++)
    {
        if (strcmp(v[i].name, DeleteName) == 0)
        v.erase(v[i]);    //error C2664: std::_Vector_iterator<_Myvec>                //std::vector<_Ty>::erase(std::_Vector_const_iterator<_Myvec>): невозможно преобразовать параметр 1 из "char [30]" //в     "std::_Vector_const_iterator<_Myvec>" with
//1>          [
//1>              _Myvec=std::_Vector_val<std::_Simple_types<Work>>,
//1>              _Ty=Work
//1>          ]
//1>          and
//1>          [
//1>              _Myvec=std::_Vector_val<std::_Simple_types<Work>>
//1>          ]
//1>          Ни один конструктор не смог принять исходный тип, либо разрешение перегрузки конструктора //неоднозначно
    }
 
}
 
void Work :: menu(int n)
{
    cout << "" << endl;
    cout << "-------------------------------------------------------------------------------" << endl;
    cout << "" << endl;
    cout << "                     - 1 -  Создать предметный указатель." << endl;
    cout << "                     - 2 -  Поиск слова." << endl;
    cout << "                     - 3 -  Итог предметного указателя." << endl;
    cout << "                     - 4 -  Удаление элемента." << endl;
    cout << "" << endl;
    cout << "-------------------------------------------------------------------------------" << endl;
    cout << "" << endl;
 
    char z = tolower(getch());
 
    switch(z)
    {
        case '1' : input(n); break;
        case '2' : search(n); break;
        case '3' : output(n); break;
        case '4' : deletetask(n); break;
    }
}
 
int main()
{
    
    int n=3;
 
 
    setlocale(0,"rus");
 
  
    Work w;
    for(;;)
    {
        w.menu(n);
    }
    system("pause");
    return 0;
}
 
Текущее время: 18:35. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru