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

Односвязный список: функция добавления записи не работает - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Решение систем линейных алгебраических уравнений http://www.cyberforum.ru/cpp-beginners/thread889667.html
Вот есть СЛАУ методом Зейделя. Размер системы n параметр. n <= 10. над переделать, чтоб был метод квадратных корней и n<=12 помогите плз #include "stdafx.h" #include <stdio.h> #include <conio.h> #include <math.h> #include <iostream> using namespace std; void main() {
C++ Итератор, вставка в произвольное место списка Здравствуйте. Подскажите как вставить значение в произвольное место списка используя итератор. Эта функция должна выглядеть так: iterator insert(iterator position, const T& value); Вот кидаю исходник итератора, если нужно кину всю программу class iterator { public: _Node *p; iterator(void) http://www.cyberforum.ru/cpp-beginners/thread889660.html
C++ Удаление объекта класса
Помогите с удалением объекта класса: void badstuddel(Student spis, int n) { for(int i=0;i<n;i++) if(spis.getpoint()<4) delete (* spis); } ВЫдаёт: C:\Users\Сергей\Downloads\mod7rand (2).cpp|105|error: no match for 'operator' in '* spis'| Если же я делаю просто:
Найдите ошибку C++
Помогите найти ошибку в программе /*prog222.pas Программа решает следующую задачу: Даны вещественные положительные a, b, c, d, e, f. Считаем, что пары чисел a и b, c и d, e и f обозначают размеры первого, второго и третьего прямоугольника соответственно. Выяснить, можно ли внутри одного из прямоугольников уместить два других, не накладывая один на другой. */ #include <iostream>
C++ Дан текстовый файл. Перепишите его в выходной файл, удалив все знаки препинания http://www.cyberforum.ru/cpp-beginners/thread889634.html
Не работает , выдает ошибку...Можно решение с комментариями!!?) #include <iostream> #include <fstream> using std::ifstream; using std::ofstream; #include <string> using std::string;
C++ Подготовка и решения на ПЭВМ задач обработки массивов с использованием указателей помогите пожалуйста((( В одномерном массиве, состоящем из n действительных элементов, вычислить: • умножение положительных элементов массива; • сумму элементов массива, расположенных до минимального элемента. Упорядочить по возрастанию отдельно элементы, стоящие на четных местах, и элементы, стоящие на нечетных местах. подробнее

Показать сообщение отдельно
Jazzis
1 / 1 / 0
Регистрация: 27.05.2013
Сообщений: 15
03.06.2013, 20:04     Односвязный список: функция добавления записи не работает
Вообщем написал функцию для добавления записи в конец, все работает без ошибок, но когда просматриваю список функцией для просмотра, пишет, что он EMPTY. Я пробовал закомментить curr = head;, но нет возможности проверить работу. Вот весь код:
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
#include <iostream>
#include <stdlib.h>
#include <string.h>
#include <stdio.h>
 
using namespace std;
 
struct Person {
    int id; 
    int age;
    int number;
    char* fio;
    char* prof;
    char* party;
    bool sud;
};
 
struct Base {
    Person person;
    struct Base *next;
} *head;
 
Base* append(void) {
   struct Base *curr;
   curr = (struct Base *)malloc(sizeof(struct Base));
   while (curr->next != NULL)
      curr = curr->next;
   curr->next = new Base;
   curr = curr->next;
   //curr->data = x;
   //curr->next = NULL;
   return curr;
}
 
void display(struct Base *curr) {
   int i = 0;
   curr = head;
   //curr = (struct base *)malloc(sizeof(struct base));
   if (curr == NULL) {
      cout<<"EMPTY"<<endl;
      return;
   }
   while (curr->next != NULL) {
      printf("%d %s %d", curr->person.id,curr->person.fio,int(curr->person.sud));
      curr = curr->next;
      i += 1;
   }
   printf("\nTotal lines: %d \n", i);
}
 
int main()
{
    struct Base * db = NULL;
    int op1,op2;
    int num1(0),num2(0); // number of lines
    do {
        cout << "\n[1] New line\n[2] View\n[0] Exit\n>> ";
        cin >> op1;
        switch (op1) {
            case 1: {
                int i,k,x;
                char text[150];
                bool lgc;
                cout << "Number of lines: ";
                cin >> k;
                for (i=num1; i<k+num1 ;i++) {
                    db = append();
                    cout << "\nNumber of line: " << i+1 << endl;
                    db->person.id = i+1;
 
                    cout << "Fullname: ";
                    cin >> text;
                    db->person.fio = (char*)malloc(strlen(text)+1);
                    strcpy(db->person.fio, text);
 
                    cout << "Age: ";
                    cin >> x;
                    db->person.age = x;
 
                    cout << "Job: ";
                    cin >> text;
                    db->person.prof = (char*)malloc(strlen(text)+1);
                    strcpy(db->person.prof, text);
 
                    cout << "Party: ";
                    cin >> text;
                    db->person.party = (char*)malloc(strlen(text)+1);
                    strcpy(db->person.party, text);
 
                    cout << "Precinct number: ";
                    cin >> x;
                    db->person.number = x;
 
                    cout << "Record: ";
                    cin >> lgc;
                    db->person.sud = lgc;
                    db->next = NULL;
                }
                num1 = i;
                break;
            };
            case 2: 
                display(db);
                break;
            case 0: break;
            default: printf("Invalid command");
        }
    } while (op1 != 0);
}
Вроде же добавляются, или нет?
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:38. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru