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

Создать линейный список по уже имеющийся структуре "Записная книжка" - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ В массив B[n] занесены натуральные числа. Найти сумму тех элементов, которые кратны данному f http://www.cyberforum.ru/cpp-beginners/thread840268.html
В массив B занесены натуральные числа. Найти сумму тех элементов, которые кратны данному f. Добавлено через 55 минут В массив B занесены натуральные числа. Найти сумму тех элементов, которые кратны данному f. Код Pascal var a:arrayof integer; s,i,k:integer; begin
C++ разработать программу, позволяющую расшифровать файл по паролю, вводимому пользователем Здравствуйте! Задали лабу. НУЖНО зашифровать текстовый файл по произвольному паролю и разработать программу, позволяющую расшифровать файл по паролю, вводимому пользователем. В случае успешной расшифровки вывести на экран содержимое файла. ПОМОГИТЕ!!!! http://www.cyberforum.ru/cpp-beginners/thread840265.html
C++ Какой unicode у коньюнкции?
(wchar_t)0x2227 выводит квадрат.
в прямоугольной целочисленная матрицы отсортировать элементы которые размещены на главной диагонали по возрастанию C++
в прямоугольной целочисленная матрицы отсортировать элементы которые размещены на главной диагонали по возрастанию
C++ Работа с матрицей http://www.cyberforum.ru/cpp-beginners/thread840194.html
Дорогие друзья программисты привела меня к вам нужна,напишите пожалуйста программу на языке с++ вот условие: Дана прямоугольная целочисленная матрица определить: 1)колличество строк содержащий хотя бы один нулевой элемент. 2)номер столбца в котором находиться самая длинная серия одинаковых элементов. Заранее спасибо!!!!!
C++ Функции Помогите переделать эту строку,должно быть три аргумента как в объявлениии-sort1( digits.begin(), digits.end() ); при учете что в объявлении этой функции 3 аргумента-void sort1 (int a,int g, int n) подробнее

Показать сообщение отдельно
yoghurt92
373 / 344 / 22
Регистрация: 17.05.2012
Сообщений: 1,049
19.04.2013, 08:30     Создать линейный список по уже имеющийся структуре "Записная книжка"
Mako-chi, вот так

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
#include <iostream>
#include <fstream>
#include <locale>
using namespace std;
 
/*твоя структура*/
struct book
{ 
    char name[10];
    long int number;
    int birthday[3];
 
    /*я добавил функцию для ввода данных*/
    void input(ifstream &fin){
        fin >> name >> number >> birthday[0] >>
            birthday[1] >> birthday[2];
    }
 
    /*функция для вывода данных*/
    void output(){
        cout << name << '\t' << number << '\t' << birthday[0] << '.' <<
            birthday[1] << '.' << birthday[2] << '\n';
    }
};
 
/*в элементах списка находяться указатели на нашу стрктуру
и каждый элмент списка указывает на следующий*/
struct ListNode
{
    book *data;
    ListNode *next;
};
 
class List
{
    private:
        ListNode *first;            //голова списка
 
    public:
        List()
        {
            first = NULL;           //список изначально пустой
        }
 
        void addAtFront(ifstream &fin)         //функция добавления в начало списка
        {
            book *in = new book;        //выделяем память под указатель на структуру
            in -> input(fin);              //вводим данные о человеке
 
            ListNode *Ptr = new ListNode;       //выделяем память под элемент списка
            Ptr -> data = in;                   //кладем данные о человеке
            Ptr -> next = NULL;                 //следующих данных нет(NULL - признак конца списка)
 
            if(first == NULL)               //если список пуст
            {
                first = Ptr;                //введенные данные будут первой записью
            }
            else                            //иначе
            {
                ListNode *Ptr_f = first;            //первая запись(голова списка)
                first = Ptr;                        //головой становится новая запись
                Ptr -> next = Ptr_f;                //новая запись указывает на бывшую голову
            }
        }
 
        void removeAtFront()            //удаление первой записи
        {
            if(first == NULL)                   //если список пуст
                wcout << L"Список пуст!\n";
            if(first -> next == NULL)           //для списка с 1 элементом
            {
                delete first;               //удалили голову
                first = NULL;               //список пуст
            }
            else
            {
                ListNode *temp = first -> next; //элемент после головы(будет новой головой)
 
                delete first;       //удаляем голову
                first = temp;       //теперь следующий элемент после головы стал головой
            }
        }
 
        void showItem()                 //вывод списка
        {
            ListNode *current(first);       //голова списка
 
            if(current == NULL)             //если список пуст выводим сообщение
                wcout << L"Список пуст!";
            else
            {
                wcout << L"Список:\n";
                while(current != NULL)          //идем по списку
                {
                    current -> data -> output();        //выводим элемент
                    current = current -> next;          //переходим к следующему
                }
            }
 
            cout << endl;
        }
};
 
int main()
{
    wcout.imbue(locale(".866"));
    wcin.imbue(locale(".866"));
 
    ifstream fin("file.txt", ios::in);
 
    List op;                    //объявляем объект класса
    op.addAtFront(fin);            //вызов метода добавления элемента списка
    op.addAtFront(fin);            //вызов метода добавления элемента списка
    op.showItem();              //вызов метода вывода списка на консоль
 
    fin.close();
    cout << "\n\n";
    return 0;
}
 
Текущее время: 14:00. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru