С Новым годом! Форум программистов, компьютерный форум, киберфорум
Наши страницы

Простой список в виде массива.Как работать с элементами списка-массива через единую функцию - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Map STL - максимальный объем памяти http://www.cyberforum.ru/cpp-beginners/thread153424.html
Пишу модуль для программы - что-то вроде переводчика. Есть словарь синонимов (40+мб). Загружаю его в map, но после 740000+ ключа, мой словарь больше не растет. Пробовал тест: вместо своих...
C++ Полная форма разветвления Оплата работ зависит от типа работы: "а", "b", "c" и вычисляется по неким формулам записаным в коде. Для каждого типа работы есть процент налога 10%, 15%, 20% для "а", "b", "c" соотвецтвенно. Нужно... http://www.cyberforum.ru/cpp-beginners/thread153407.html
C++ Двумерный массив
помогите доделать программу. нужно сдавать через 2 дня Написать программу, интегрирующую случайный двумерный массив из 0 и 1 с помощью датчика случайных чисел RANDOM. Размер массива N*M и доля в...
C++ Оператор delete[]
Код: #include <iostream> #include <cstdlib> #include <ctime> #define stop __asm nop int main() { int N,M; N=3;
C++ Имитация работы АЗС (ООП) http://www.cyberforum.ru/cpp-beginners/thread153396.html
Задача: написать программу, имитирующая работу АЗС в объектно ориентированном виде. У меня есть программа, написаная на delphi, но она не в ООП. Если надо могу её код написать.
C++ Двумерный Динамический массив Здравствуйте, такая проблема: не могу задать int** и char**...проблема в том что в функцию передются их размеры , но они не константы и компилятор пишет ошибку, и не очень понимаю как выделять... подробнее

Показать сообщение отдельно
USHЁL
0 / 0 / 0
Регистрация: 15.11.2009
Сообщений: 93

Простой список в виде массива.Как работать с элементами списка-массива через единую функцию - C++

13.07.2010, 15:28. Просмотров 707. Ответов 1
Метки (Все метки)

Добрый день!Подсобите,как реализовать Простой список,но не через шаблоны или создание указателей,а как бы в виде массива.(Ну,или ваш вариант через указатели или шаблоны).
Кто-то наверно подумает,что опять изобретают велосипед=)
Сама проблема кроется в том,что нужно организовать просмотр элементов списка и каких либо действий над ним через единую общую функцию( void Visit(void (*pf)(Item &) ),которая принимает указатель на другую функцию в качестве аргумента. pf-указывает на функцию(не функцию-член),которая принимает ссылку на аргумент типа Item,где Item-тип элементов списка.
Попробовал создать 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
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
//list.h
#ifndef LIST_H_
#define LIST_H_
class Data
{
    private:
        char fullname[35];//elements of spiska List
        double payment;//elements of spiska List
    public:
        Data();
        Data(const char fn, double pm);
        ~Data();
        void Rename();
        void Repayment();
};
typedef Data Item;// spisok aka List aka massiv objects of class Data
class List
{
    private:
        enum{MAX = 10};
        Item Spisok[MAX];// :spisok aka List aka massiv objects of class Data
        int top;
        double summ;
    public:
        List();
};
 
        [COLOR="yellow"]void visit(void (*pf)(Item & pa));[/COLOR]
        void isempty(const Item & it);
        void isfull(const Item & it);
        void push(const Item & it);//dobavlayet element v spisok
        void pop(Item & it);//udalyaet element iz spiska
        void Funct_Sum(const Item & parStruct);
#endif
 
____________________________________
//list.cpp
#include "list.h"
#include <iostream>
//class Data
Data::Data()
{
    strspy(fullname,"no name")
    payment = 0;
}
 
Data::Data(const char fn, double pm)
{
    strncpy(fullname,fn,34);
    fullname[34] = '\0';
    payment = pm;
}
 
Data::~Data()
{
    
}
void Data::Rename(char fn)
{
      strncpy(fullname,fn,34);
      fullname[34] = '\0';
}
void Data::Repayment(double pm)
{
    paement = pm;
}
 
//class List
List::List()
{
    top = 0;
}
void isempty(const Item & it)
{
    if(top == 0)
     cout<<"Spisok pust\n";
}
void isfull(const Item & it)
{
    if(top == MAX)
      cout<<"Spisok polon\n;
}
void push(const Item & it)
{
    if(top < MAX)
    {
        Spisok[top++] = it;
        return true;
    }
    else
     return false;
}
 
void pop(Item & it)
{
    if(top > 0)
    {
        it = Spisok[--top];
        return true;
    }
    else
     return false;
}
void Funct_Sum(const Data & parData)
{
    using namespace std;
    static double summ = 0; 
    summ += parData.payment;
    cout<<" Otchet po pribili :"<<summ<<endl;
}
void visit(void (*pf)(Item & pa))
{
    cout<<(*pf)(Item & pa);
}
_________________________
//lister.cpp
#include <cstdlib>
#include <iostream>
#include <cctype>
#include "list.h"
 
int main(int argc, char *argv[])
{
    using namespace std;
    List st;//pustoy spisok
    char ch;
    Data object;//object of Data
        while(toupper(ch) != 'Q')
        {
            while(cin.get() != '\n')
             continue;
             if(!isalpha(ch))
             {
                    cout<<'\a';
                    continue;
             }
                               
                visit(isfull(st));
                visit(push(object));
                visit(isempty(st));
                visit(pop(object));
                visit(Funct_Sum(object));
        }  
        cout<<"Vsego nailuchshego!\n";                               
    system("PAUSE");
    return EXIT_SUCCESS;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.