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

Преобразовать программу с массивом в двусвязный список - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ разработать класс прямоугольник http://www.cyberforum.ru/cpp-beginners/thread313479.html
разработать класс прямоугольник. определить конструктор и деструктор. реализовать объявленные методы(3 метода) доступа к данным. Вот! задачу довел до этого... но выдает ошибки, незнаю как исправить(( #include <iostream> #include <string> class Rectange //объявление класса Rectange
C++ Работа на 2х сторонний список Делаю курсач по программированию. Курсач состоит из меню с вопросами. Один из пунктов " Алфавитный список". В нем у меня список марок машин и кол-во л.сил сколько приходится на ту или инную машину. Пример" Хендаи 122 Ауди 220 и т.д. А препод попросил сделать 2х сторонний список. Т.е. к примеру Машинный список располагается по алфавиту,а при нажатии должен от обратного стороиться. " От А... http://www.cyberforum.ru/cpp-beginners/thread313456.html
C++ Количество нулей в записи числа
Помогите пожалуйста написать эдакое... Дано натуральное число n. Подсчитать количество нулей в записи данного числа в десятичной системе счисления. На С# написал примерно, а на С++ немогу... Вот код на с#, мож кто сможет переделать в с++? using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using...
Найдите кратчайшие пути от фиксированной вершины произвольного бесконтурного графа C++
Найдите кратчайшие пути от фиксированной вершины произвольного бесконтурного графа. Граф задан списками смежности. После завершения работы с динамическими структурами данных необходимо освободить занимаемую ими память. Подскажите какой алгоритм использовать!
C++ Бесконечный цикл http://www.cyberforum.ru/cpp-beginners/thread313413.html
Здравствуйте. Программа должна принимать некоторые значения, обрабатывать их и выдавать в виде статистики (нарисовать звездочками). Вот как раз во время печати звездочек и получается бесконечный цикл. Как его побороть? #include <iostream> // // #include <iomanip> // using namespace std; // //
C++ Ошибка с массивами Доброго времени суток. Пишу игру двадцать одно очко. Возникли проблемы с массивами. Есть класс, где хранятся: названия карт, значения карт, сумма всех очков и пара функций для генерации карт. Сам класс: #ifndef _KARDS_H #define _KARDS_H class kards { public: AnsiString kard; int znachenie; подробнее

Показать сообщение отдельно
dfrisk
0 / 0 / 0
Регистрация: 15.11.2010
Сообщений: 8
05.06.2011, 15:51     Преобразовать программу с массивом в двусвязный список
Собственно необходимо решить данную задачу с помощью двусвязаного списка( полностью ну или просто дописать)

Описать структуру NOTE, содержащую следующие поля:
NAME - фамилия, имя;
PHONE - номер телефона;
BDAY - день рождения (массив из трех чисел);
Написать программу, выполняющую следующие действия:
Создать массив blocknote, состоящий из 5 структур типа NOTE; записи
должны быть упорядочены по датам рождения;
Вывод на дисплей информации о человеке,
номер телефона которого введен с клаиватуры;
Если такого нет, то вывести соответствующие сообщение.


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
#include <cstdlib>
#include <iostream>
#include <stdio.h>
 
 
using namespace std;
 
 
int main() {int i; int j; int bd[2]; long long int ph;
    struct note {
        char name[15]; 
        long long int phone; 
        int bday[2];
 
    };
    struct note blocknote[5]; // Основной массив структур
    struct note tmp; // Временная структура необх. для сортировки
    
 
    
    for (i=0;i<3;i++)
    {cout << "\nImya i familia:\n";
        cin.ignore();
        cin.getline(blocknote[i].name, 15);
        cout << "\nTelefon:\n";
        cin >> blocknote[i].phone;
        cout << "\nBirthday(YYYY):\n";
        cin >> blocknote[i].bday[0];
        cout << "\nBirthday(MM):\n";
        cin >> blocknote[i].bday[1];
        cout << "\nBirthday(DD):\n";
        cin >> blocknote[i].bday[2];
        }
    
    for (i=0;i<3;i++)
        bd[i]=(blocknote[i].bday[0]*10000)+(blocknote[i].bday[1]*100)+(blocknote[i].bday[2]);
    //воводи особую переменную для сортировки
    for(i = 0 ; i < 3 ; i++) { 
       // сравниваем два соседних элемента
       for(j = 0 ; j < 3 - i - 1 ; j++) {  
           if(bd[j] < bd[j+1]) {           
              // если они идут в неправильном порядке, то  
              //  меняем их местами 
              tmp = blocknote[j]; blocknote[j] = blocknote[j+1]; blocknote[j+1] = tmp;}}}
    
    
    
    cout << "\nSortirovka vipolnena...n";
    cout << "\n Samii molodoi:"<< blocknote[0].name <<"\n"; //проверка правильности сортировки
    cout <<"Vvedite nomer teleofona iskomogo 4eloveka:";
    cin >> ph; j=0; //Телефон для сравнения
    for (i=0;i<3;i++) {if (ph==blocknote[i].phone) {cout << "Etot 4elovek:" << blocknote[i].name <<"\n"; j=1;}} // Вывод совпадений
    if (j!=1) cout<< "\nNe naideno!\n"; // Если совпадений не было, то вывод соответствующего сообщения
    
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 13:23. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru