Форум программистов, компьютерный форум 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
Сообщений: 45

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

12.05.2013, 14:39. Просмотров 1534. Ответов 12
Метки (Все метки)

Описать клас *предметный указатель*. Каждый компонент указателя содержит слово и номер страницы, на которых ето слово встречаеться. Количество номеров страницы, которые относяться к одному слову, от одного до десяти. Предусмотреть возможность формирования указателя с клавиатуры и с файла, итог указателя, итог номеров страниц для заданого слова, удаление элемента с указателя.

Написал всё, кроме считывания с файла и удаления. Помогите, пожалуйста. Напишите хотя бы удаление.

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
151
152
153
154
155
156
157
158
159
160
161
162
#include <iostream>
#include <stdlib.h>
#include <conio.h>
#include <ctime>
#include <locale.h>
 
using namespace std;
 
struct List 
{
       char word[100];
       int page[10];
       List *next;
       List *pred;
};
void CreateList (List *&head,int n,int *g) 
{
    char w[100];
    List *p;    
    char k;
    cout<<"Добавить элемент? (Yes/No) : ";
    cin>>k;
    int s=0;
    while (k=='y')
    {
        p=new List;  
        cout<<"Введите слово :";
        cin>>w;
        strcpy(p->word,w);
        char h='y';   
        n=0;
        cout<<"Введите номера страниц : "<<endl;
        while (h=='y' && n<10)   
        {
            cin>>p->page[n];
            n++;
            cout<<"ещё? (Yes/No) :";
            cin>>h;              
        }
        g[s]=n;
        s++;
        p->next=head;
        p->pred=head->pred;
        head->pred=p;
        p->pred->next=p;
        cout<<"Добавить элемент в ? (Yes/No) : ";
        cin>>k;
    }
   return;
}
int PrintList (List *&head,int *g) 
{     
    int s=0;  
    List *p;
    p=head->next;
    if (head->next==head)
    {
       cout<<"Список пуст";
       return 0;
    }
    else
    {
        cout<<"Предметный указатель :"<<endl;  
        while (p->next!=head->next)
        {
            cout<<p->word<<" : ";
            for (int i=0;i<g[s];i++)
               if (i!=g[s]-1) 
                  cout<<p->page[i]<<",";
               else 
                  cout<<p->page[i]<<".";   
            cout<<endl;
            p=p->next; 
            s++;                
        }     
    }                               
    return 0;       
}
void search (List *&head,int *g)
{
       int j=0;
       char w[100]; 
       List *p;
       p=head->next;
       cout<<"Задайте слово : ";
       cin>>w;
       int f=0;
       while(p->next!=head->next)
       {
          if (strcmp(p->word,w)==0) 
          {
              cout << "" << endl;
               cout<<"Страницы : ";                     
               for (int i=0;i<g[j];i++)                     
                  if (i!=g[j]-1) 
                     cout<<p->page[i]<<",";
                  else 
                     cout<<p->page[i]<<".";   
               f=1;                       
          }  
          if (!f)
             cout<<"Данное слово не встречаеться";
          j++;
          p=p->next;                                                          
     
    } 
    return;    
}
 
void deletetask()
{
 
}
 
int main()
{
    setlocale (LC_ALL, "Russian");
 
    int t=0;
        int k[10];
    int r;
    List *head;
    
    head=new List; 
    head->next=head;                              
        head->pred=head; 
    for(;;)
    {
        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' :
        
                     CreateList(head,t,k);
                  
                     break;
 
            case '2' : 
                 
                    search(head,k);
                    break;
 
            case '3' : 
                     PrintList(head,k);
                     break;
    }
    }
    system("pause");
    return 0;
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru