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

Функция поиска в динамическом списке - C++

Восстановить пароль Регистрация
 
viktorrrr
42 / 42 / 1
Регистрация: 11.02.2010
Сообщений: 358
15.05.2011, 19:02     Функция поиска в динамическом списке #1
Помощь нужна в реализации поиска в динамическом списке.. Мозг не понимает еще. Ошшень желательно бы не смешивать с С. Ибо учу всего 2 с половиной месяца и отхождения от С++ вызывают панику)

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
#include <cstdio>
#include <cstdlib>
#include <iostream>
#include <string.h>
using namespace std;
 
 
class List
{
  public:
        char szName[128];
        // указатель на следующую запись в списке
        List* pNext;
};
 
// указатель на первую запись списка
List* pHead = 0;
 
// добавление нового члена в список
void add(List* pNDS)
{
        pNDS->pNext = pHead;
        // заголовок указывает на новую запись
        pHead = pNDS;
}
 
// чтение имени
List* getData()
{
        // читаем имя
        char nameBuffer[128];
        cout << "\nVvedite imja:";
      
        cin  >> nameBuffer;
        
        // усли "exit" - выход
        if ((stricmp(nameBuffer, "exit") == 0))   //сравнение exit с nameBuffer . Их равенство обозначается 
        {                                           // как ноль
                return 0;
        }
 
        // новая запись для заполнения
        List* pNDS = new List;
        
        // заполнение поля имени и обнуление указателя
        strncpy(pNDS->szName, nameBuffer, 128);
        pNDS->szName[127] = '\0';
        pNDS->pNext = 0;
 
        // возврат адреса созданного объкта
        return pNDS;
        cin>>nameBuffer;
 
        if((strcmp(nameBuffer,pNDS->szName)==0))
        {
            cout<<nameBuffer;
        }
 
 
        
}
 
 
int main()
{
       
    cout << "zapolnite spisik\n"
                 << "Esli spisok zakon4en, naberite 'exit' \n";
 
        // создание объекта NameDataSet
        List* pNDS;
        while (pNDS = getData())
        {
                // добавление в конец списка
                add(pNDS);
        }
 
        cout << "Entries:\n";
        pNDS = pHead;
        while(pNDS)
        {
                // вывод текущей записи
                cout << pNDS->szName << "\n";
 
                // получение следующей записи
                pNDS = pNDS->pNext;
        }
 
        
        system("PAUSE");
        return 0; 
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
15.05.2011, 19:02     Функция поиска в динамическом списке
Посмотрите здесь:

C++ Функция сортировки и поиска
C++ Рекурсивная функция нахождения максимального элемента в списке
C++ Функция поиска в файле
Функция, удаляющая все элементы в списке C++
C++ Функция для удаления элемента в двумерном динамическом массиве. В чем ошибка?
Функция / метод поиска C++
Организация поиска в списке. Исправить ошибку в методе поиска C++
C++ Удаление c параметром в динамическом списке

Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 16:21. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru