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

Объясните код - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Разработать С++ программу с использованием циклических алгоритмов http://www.cyberforum.ru/cpp-beginners/thread696935.html
Создать С++ программу, повторяет ввод с клавиатуры целых чисел, пока не будет введено заранее заданное М, вычисляет и отображает количество введенных чисел.
C++ Кодирование/декодирование в Base64 #include<iostream.h> #include<stdio.h> #include<stdlib.h> #include<conio.h> /* ** Translation Table as described in RFC1113 */ static const char cb64="ABCDEFGHIJKLMNOPQRSTUVWXYZabcdefghijklmnopqrstuvwxyz0123456789+/"; http://www.cyberforum.ru/cpp-beginners/thread696929.html
for, while и do while C++
Решите каждую задачу тремя способами - используя операторы цикла for, while и do while: 1. Напишите программу, которая выводит все целые числа из диапазона от А до В (А<В), оканчивающиеся на цифру X. 2. Напишите программу, которая выводит все целые числа из диапазона от А до В, кратные трем (А<В). 3. Напишите программу, которая выводит только отрицательные четные числа из диапазона от А до В...
Программа, определяющая разницу в сутках между двумя датами C++
Составьте программу определяющую разницу в сутках между двумя датами. Нельзя использовать условный оператор , помогите пожалуйста Помогите пожалуйста , там формулу надо составить какую-то
C++ Перегрузка методов http://www.cyberforum.ru/cpp-beginners/thread696910.html
Помогите написать программу. Создать массив объектов, и с помощью методов класса предусмотреть следующие возможности: • вывод планет в последовательности согласно расстоянию к солнцу; • поиск планет с наибольшим количеством спутников; • поиск наибольшего по массе объекта (масса планеты + массы всех спутников). Класс «Планета» с полями: • название (public) • спутники (private)
C++ Последовательность обработки данных Ребят, подскажите пож-ста алгоритм составления данной программы, хотя бы кратко, а то даже начать не знаю с чего, и какие темы помогут в выполнении данной программы. Преподаватель сказал, что можно сделать через функции, но не обязательно. Спасибо. (если не по теме, извините, не знаю куда еще написать, этот сайт, вроде как, лучший ). P.S Если кому-то скучно, можете написать полностью программу... подробнее

Показать сообщение отдельно
_Kate_
0 / 0 / 0
Регистрация: 12.09.2012
Сообщений: 92
Записей в блоге: 1

Объясните код - C++

13.11.2012, 22:58. Просмотров 203. Ответов 0
Метки (Все метки)

вот у меня есть код реализации структуру (связного списка).
но не могу разобраться что делает там указатели и куда они указывают.
Имееться структура Node (указатель на предыдущий и следующий элемент)
Так же есть класс Список состоящий с узлов.
код выполняет следующие действия : печатает все слова, отличающиеся от последнего по алфавиту слова текста, перед печатью удалив из слова все гласные буквы.
помогите именно разобраться с указателями типа next->TAIl ...и.т.п
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
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
#include <iostream>
#include <conio.h>
using namespace std;
 
 
struct Node  //структура узел    
{
    char symb;
    Node *next,*prev; //указатель на следующий и предидущий элемент
};
 
class List // сам список
{
    Node *Head, *Tail; // голова списка и хвост
public:
    List(); //конструктор
    ~List(); //деструктор 
    bool Getchar(); //ввод с клавиатуры и проверка на валидность бук
    void Show(); 
    char ThrdSymb();
    void DelWords(char);
    void DelVowel();
    void Mem();
};
 
 
List::List()
{
Head=NULL; // чистим голову
Tail=NULL;// и хвост
}
 
bool List::Getchar()
{
char tempare;
setlocale(LC_CTYPE,"Russian");
do 
{
    tempare=getch(); // с клавиатуры получаем буквы
    cout<<tempare;
if (!( ((int)tempare>96 && (int)tempare<123) || ((int)tempare>64 && (int)tempare<91) || 
((int)tempare==32) || ((int)tempare==46) || ((int)tempare==10)))
{
cout<<"\n Вы не ввели букв";                
    cin.get();
                return 1;
        }
else
        {
            Node *temp=new Node; 
            temp->next=NULL;  
            temp->symb=tempare;
    
            if (Head!=NULL)
            {
                temp->prev=Tail; 
                Tail->next=temp; 
                Tail=temp; 
            }
else 
            {
                temp->prev=NULL; 
                Head=Tail=temp; 
            }
 
 
        }
    }   while (tempare!='.');
    return 0;
}
 
List::~List() 
{   
    while (Head)
    {
        Tail=Head->next; 
        delete Head; 
        Head=Tail; 
    }
}
 
 void List::Show()
{
    Node *temp=Head; 
    while (temp!=NULL) 
    {
        cout<<temp->symb; 
        temp=temp->next; 
    }
    cout<<"\n";
    delete temp;
}
 
char List::ThrdSymb()
{
    Node *temp=Head;
    int ch=0;
    while (temp!=NULL)
    {
        if (((int)temp->symb==32) || (((int)temp->symb==10) && (int)temp->next->symb!=32))
        {
            ch++;
            if ((ch==2) && ((int)temp->next->symb!=32))
            {
                return (temp->next->symb);
                break;
            }
        }
        temp=temp->next;
    }
    cout<<"Должно быть как минимум три слова";
    cin.get();
    cin.get();
    return NULL;
}
 
void List::DelVowel() //ASCII проверка по символам
{
    Node *temp=Head;
    while (temp->next!=NULL)
    {
        if (((int)temp->symb==65) || ((int)temp->symb==97)  || 
            ((int)temp->symb==69) || ((int)temp->symb==101) ||
            ((int)temp->symb==73) || ((int)temp->symb==105) || 
            ((int)temp->symb==79) || ((int)temp->symb==111) ||
            ((int)temp->symb==85) || ((int)temp->symb==117) || 
            ((int)temp->symb==89) || (
            (int)temp->symb==121))
        {
            Node *temp_prev=temp->prev;
            Node *temp_next=temp->next;
            
            if (temp->prev!=NULL)
            {
                temp_prev->next=temp_next;
                temp_next->prev=temp_prev;
                delete temp;
                temp=temp_prev->next;
            }
            else
            {
                Node *temp_del=temp;
                Head=Tail=temp_next;temp=temp->next;delete temp_del;
            }
        }
        else
            temp=temp->next;
    }   
}
 
void List::DelWords(char symb_pr)
{
    Node *temp=Head;
    Node *temp2=temp->next;
    Node *EndW;
 
    while (((int)temp->symb==symb_pr) && (temp==Head))
    {
        EndW=temp;
        do
        {
            EndW=EndW->next;
        }
        while ((int)EndW->symb!=32);
        
        Node *temp_next=EndW->next;
        Head=temp_next;
        temp_next->prev=Head;
 
        temp=Head;
        temp2=temp->next;   
    }
 
    while (temp2->next!=NULL)
    {
        if (((temp2->symb==symb_pr) && ((int)temp->symb==32))) 
        {
            EndW=temp2;
            do
            {
                EndW=EndW->next;
                if (EndW->next==Tail)
                    break;
            }
            while ((int)EndW->symb!=32);
 
            Node *temp_prev=temp;
            Node *temp_next=EndW->next;
            temp_prev->next=temp_next;
            temp_next->prev=temp_prev;
 
            temp=temp_prev;
            temp2=temp->next;
        }
        else
        {
            temp=temp->next;
            temp2=temp->next;
        }
    }   
}
 
void List::Mem()
{
    int size=0;
    Node *temp=Head; 
    while (temp!=NULL) 
    {
        size=size+sizeof(temp->symb)+sizeof(temp->next)+sizeof(temp->prev);
        temp=temp->next; 
    }
    size=size+sizeof(Head)+sizeof(Tail);
    std::cout<<"\nSize: "<<size<<"\n";
}
 
 
void main()
{
    List a;
    char temp;
    bool rtrn=0;
    
rtrn=a.Getchar();
    if (rtrn==1)
        return;
 
a.Mem();
 
temp=a.ThrdSymb();
    cout<<"\nThird_symb_is:"<<temp<<"\n";
a.DelWords(temp);
a.DelVowel();
a.Mem();
a.Show();cin.get();
cin.get();
}
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru