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

Обмен элементов динамического списка - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Дана целочисленная матрица A(N, M). Borland С++ for dos http://www.cyberforum.ru/cpp-beginners/thread596968.html
1)Дана целочисленная матрица A(N, M). Вычислите сумму и произведение тех её элементов, которые при делении на два дают нечётное число. 2)Дана квадратная вещественная матрица размерности n. Найти количество нулевых элементов, стоящих выше и ниже побочной. --------- Код к первой программе #include<iostream.h> #include<conio.h> void main() { int a,N,M,i,j,sum=0,umn=1,del; cout<<"Vvedite...
C++ Защита курсовой работы! Оставьте пожалуйста комментарии о курсовой работе! Может чего- нибудь еще добавить или убрать??? Да и вообще правильно я сделал или нет? Дайте пожалуйста ответ! Скоро защита,нужна помощь специалистов! 1 Постановка задачи Необходимо создать однонаправленный динамический список,, содержащий информацию о реках. Список должен состоять из 4 полей: 1 поле – название реки, 2 поле - длина... http://www.cyberforum.ru/cpp-beginners/thread596965.html
Программа написанная мной не отвечает C++
Я написал программу на c++ которая делает следуещее: просит ввести цифру, после ввода выводит на экран, следующий раз просит тоже ввести значение, но если это значение самое большое или самое маленькое среди введенных раньше, на экран высвечивется сообщение об этом. #include <cstdlib> #include <iostream> #include <vector> using namespace std; int main(int argc, char *argv) {
Процедуры шифрования и сортировки C++
1.Описать процедуру EncodeText(S, K), которая шифрует текстовый файл с именем S, выполняя циклическую замену каждой русской буквы на букву того же регистра, расположенную в алфавите на K-й позиции после шифруемой буквы (0 < K < 10). Например, при K = 3 «А» перейдет в «Г», «я» — в «в». Букву «ё» в алфавите не учитывать, считая, что за буквой «е» сразу идет «ж». Символы, не являющиеся русскими...
C++ функция поиска простых чисел http://www.cyberforum.ru/cpp-beginners/thread596940.html
не могу сделать функции для поиска простых чисел, вот код функции int prost(int x) { if (x/2) return true; else return false; }
C++ Перегрузка операторов Приветствую! Необходима помощь. Разработать класс Vec4 как вектор из 4-х float. Определить оператор ~ для перестановки элементов вектора в обратном порядке и операторы ввода >> и вывода <<. Напишите тестирующую программу. Программу написал, но она не работает, равно как и пара найденных в интернете примеров. Что я не подключил/в чем ошибка? #include <iostream> using namespace std; ... подробнее

Показать сообщение отдельно
Никимир
0 / 0 / 0
Регистрация: 18.01.2012
Сообщений: 12

Обмен элементов динамического списка - C++

05.06.2012, 14:18. Просмотров 370. Ответов 0
Метки (Все метки)

Здравствуйте, помогите, пожалуйста, исправить функцию для обмена элементов в списке (void swap_position),
в таком виде она ничего не меняет:
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
void swap_position(int p1, int p2)
{
    Sheet* first;
    Sheet* second;
    int    i;
 
    //nahodim pervij element
    i = 0;
    for (first = list_head; first != NULL; first = first->next)
        if (i++ == p1)
            break;
 
    // nahodim vtoroj elemnt
    i = 0;
    for (second = list_head; second != NULL; second = second->next)
        if (i++ == p2)
            break;
 
    if (second == NULL || first == NULL)
        cprintf("obmen nevozmojen \n");
    else
{
 
    // obmen
    Sheet t;
      t= *first;
    *first = *second;
    *second = t;
 
}}
Вот программа целиком:
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
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
#include <stdio.h>
#include <conio.h>
 
 
 
struct Sheet
{
    char a[20];
    int b;
    int c;
    int d;
 
    Sheet* next;
 
    void operator=(const Sheet& s)
    {
        int i;
        for (i = 0; i < 20; ++i)
           a[i] = s.a[i];
        b = s.b;
        c = s.c;
        d = s.d;
    }
};
 
Sheet* list_head;// sozdanie ykazatelya tipa Sheet
 
//------------------------------------------------------------------------------
void push_front(Sheet s)
{
   textbackground(0); textcolor(15);
     clrscr();
    //Videlaem pamat dla new element
    Sheet* new_sheet = new Sheet; //new ykazatel Sheet
    *new_sheet = s;
 
    // pomeshaem v nachalo
    new_sheet->next = list_head;
    list_head       = new_sheet;
}
 
//------------------------------------------------------------------------------
void swap_position(int p1, int p2)
{
    Sheet* first;
    Sheet* second;
    int    i;
 
    //nahodim pervij element
    i = 0;
    for (first = list_head; first != NULL; first = first->next)
        if (i++ == p1)
            break;
 
    // nahodim vtoroj elemnt
    i = 0;
    for (second = list_head; second != NULL; second = second->next)
        if (i++ == p2)
            break;
 
    if (second == NULL || first == NULL)
        cprintf("obmen nevozmojen \n");
    else
{
 
    // obmen
    Sheet t;
      t= *first;
    *first = *second;
    *second = t;
 
}}
 
 
 
//------------------------------------------------------------------------------
void remove_back()
{
    textbackground(0); textcolor(15);
     clrscr();
   printf("\n"); cprintf("“¤*«Ґ*ЁҐ ‡*ўаҐиҐ*®");
    Sheet* cur;
 
    cur = list_head;
                  if(cur==NULL) cprintf("Spisok pust");
                  else
{
    // **室Ё¬ ЇаҐ¤Ї®б«Ґ¤*Ё© н«Ґ¬Ґ*в бЇЁбЄ*
    for (cur = list_head; cur->next->next != NULL; cur = cur->next);
 
    // г¤*«пҐ¬ Ї®б«Ґ¤*Ё© н«Ґ¬Ґ*в
    if (cur->next != NULL)
    {
        delete cur->next; //ydalenie ykazatela cur->next
        cur->next = 0;
    }}
 
   printf("\n"); cprintf("&#141;*¦¬ЁвҐ Їа®ЎҐ« ¤«п Їа®¤®«¦Ґ*Ёп");
    while (getch() != 32);
 
   textbackground(1);
        clrscr();
        textbackground(7);
        gotoxy(1, 25); clreol();
        gotoxy(1, 25); clreol();
 
 
   }
//-----------------------------------------------------------------------------
void add_new_element()
{
    Sheet s;
   textbackground(0); textcolor(15);
   clrscr();
 
 
 
    printf("Vvedite nazvanie - ");
   scanf("%s", &s.a);
 
    printf("Vvedite stoimost - ");
   scanf("%d", &s.b);
 
    printf("Vvedite code tovara  - ");
   scanf("%d", &s.c);
 
    printf("Vvedite kolichestvo - ");
   scanf("%d", &s.d);
 
    push_front(s);
 
        textbackground(1);
        clrscr();
        textbackground(7);
        gotoxy(1, 25); clreol();
        gotoxy(1, 25); clreol();
 
};
//-----------------------------------------------------------------------------
  void print_list()
{
   textbackground(0); clrscr();
    textbackground(1); textcolor(14);
    cprintf("ЪДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДї");printf("\n");
    cprintf("і   Nazvanie  і  Stoim  і   Cod    і Kolich   і");printf("\n");
 
 
 
    // prohodim cherex vse elementi spiska
    for (Sheet* cur = list_head; cur != NULL; cur = cur->next)
    {
 
        // vivodim na ekran
        cprintf("і %11s і", cur->a);
        cprintf("%8d і", cur->b);
        cprintf("%9d і", cur->c);
        cprintf("%9d і", cur->d);
        printf("\n");
 
   };
    cprintf("АДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДДЩ");printf("\n");
    textbackground(0); textcolor(7);
 
    printf("\n"); cprintf("&#141;*¦¬ЁвҐ Їа®ЎҐ« ¤«п Їа®¤®«¦Ґ*Ёп");
    while (getch() != 32);
 
    textbackground(1);
    clrscr();
    textbackground(7);
    gotoxy(1, 25); clreol();
    gotoxy(1, 25); clreol();
 
 
 
};
 
 
//-----------------------------------------------------------------------------
 
 int main()
{
    char code;
 
   char menuc = 0;
 
    textbackground(1); textcolor(0); clrscr();
 
    textbackground(7);
    gotoxy(1, 25); clreol();
    gotoxy(1, 1); clreol();
 
    do {
        textbackground(7); textcolor(0);
        gotoxy(1, 1); clreol();
        gotoxy(2, 1); cprintf(" ‡*ЇЁбм ");
        gotoxy(10, 1); cprintf(" ‚лў®¤ ");
        gotoxy(17, 1); cprintf(" ЕЅЎ¬Ґ* ");
        gotoxy(23, 1); cprintf(" “¤*«Ґ*ЁҐ ");
      gotoxy(34, 1); cprintf(" ‚л室 ");
 
        textbackground(7); textcolor(4);
        gotoxy(3, 1); cprintf("‡");
        gotoxy(11, 1); cprintf("‚");
        gotoxy(18, 1); cprintf("ЕЅ");
      gotoxy(24, 1); cprintf("“");
        gotoxy(35, 1); cprintf("‚");
 
        textbackground(2); textcolor(0);
        gotoxy(2, 1); if (menuc == 1) cprintf(" ‡*ЇЁбм ");
        gotoxy(10, 1); if (menuc == 2)  cprintf(" ‚лў®¤ ");
        gotoxy(17, 1); if (menuc == 3)  cprintf(" ЕЅЎ¬Ґ* ");
        gotoxy(23, 1); if (menuc == 4)  cprintf(" “¤*«Ґ*ЁҐ ");
      gotoxy(34, 1); if (menuc == 5) cprintf(" ‚л室 ");
 
        textbackground(2); textcolor(4);
        gotoxy(3, 1); if (menuc == 1)  cprintf("‡");
        gotoxy(11, 1); if (menuc == 2)  cprintf("‚");
        gotoxy(18, 1); if (menuc == 3)  cprintf("ЕЅ");
        gotoxy(24, 1); if (menuc == 4)  cprintf("“");
      gotoxy(35, 1); if (menuc == 5) cprintf("‚");
 
        gotoxy(1, 1);
 
        code = getch();
 
        if (code == 75) menuc--;
        if (code == 77) menuc++;
 
        if (menuc > 6) menuc = 1;
        if (menuc < 0) menuc = 5;
 
        textbackground(7); textcolor(0);
        gotoxy(1, 25); clreol();
        gotoxy(2, 25);
        switch (menuc) {
        case 1: cprintf("‚ў®¤ ¤***ле б Є«*ўЁ*вгал"); break;
        case 2: cprintf("‚лў®¤ ¤***ле нЄа**"); break;
        case 3: cprintf("ЕЅЎ¬Ґ* н«Ґ¬Ґ*в®ў"); break;
        case 4: cprintf("“¤*«пҐ¬ Ї®б«Ґ¤*Ё© н«Ґ¬Ґ*в ў бЇЁбЄҐ"); break;
      case 5: cprintf("‡*ўҐаиҐ*ЁҐ а*Ў®вл"); break;
        };
 
        if (code == 13) switch (menuc){
        case 1: add_new_element(); break;
        case 2: print_list() ; break;
        case 3:
 
     textbackground(0); textcolor(15);
     clrscr();
 
    int p1, p2;
 
            printf("‚ўҐ¤ЁвҐ Ї®§ЁжЁо н«Ґ¬Ґ*в®ў.\n");
 
            printf("&#143;Ґаўл©: ");
            scanf("%d", &p1);
 
            printf("‚в®а®©: ");
            scanf("%d", &p2);
 
            swap_position(p1, p2);
 
      textbackground(1);
        clrscr();
        textbackground(7);
        gotoxy(1, 25); clreol();
        gotoxy(1, 25); clreol();
 
 
      break;
 
        case 4:
 
      remove_back(); break;
      case 5: code = -1; break;
 
      };
 
        if (code == -1) break;
 
    } while (1);
 
    return 0;
}
.
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru