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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
USHЁL
0 / 0 / 0
Регистрация: 15.11.2009
Сообщений: 93
#1

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

13.07.2010, 15:28. Просмотров 692. Ответов 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
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
13.07.2010, 15:28
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Простой список в виде массива.Как работать с элементами списка-массива через единую функцию (C++):

Указатели( с элементами массива надо работать через указатель, а не индекс) - C++
Заданы осадки по месяцам, зафиксированные метеостанцией в течение прошедшего года. Занесите эти данные в массив и определите минимальное,...

Список: Как добавлять элемент в список, не в начало и не в конец, а между 1 и 2 элементами списка? - C++
Как добавлять элемент в список, не в начало и не в конец, а между 1 и 2 элементами списка? Вот сам список: #include &lt;conio.h&gt; ...

Выделение памяти для массива через функцию и использование этого массива - C++
Я определяю свою структуру, создаю динамический массив, где будут храниться элементы этой структуры. Есть функция которая выделяет память,...

Нужно написать функцию которая будет увеличевать каждый элеммент массива на 10% (Ввод массива через клаву) - C++
#include &lt;iostream&gt; #define n 7 using namespace std ; int funct(int q) { funct=q*10% ; } int main () { int a; ...

Список в виде динамического массива - C++
Напишите программу, реализующую список в виде динамического массива.

Протабулировать и вывести функцию y=sin(x)+1 в виде одномерного массива - C++
Прошу подскажите! Как протабулировать и вывести функцию y=sin(x)+1 в виде одномерного масива?

1
Aye Aye
367 / 281 / 36
Регистрация: 17.12.2009
Сообщений: 567
14.07.2010, 04:12 #2
Цитата Сообщение от USHЁL Посмотреть сообщение
...Visit(void (*pf)(Item &) ),которая принимает указатель на другую функцию в качестве аргумента. pf-указывает на функцию(не функцию-член)...
судя по листингу это как раз должен быть указатель на функцию-член.
visit(isfull(st)); - встретив такой вызов компилятор не догадается к каким объкетам применяются функции visit и isfull, можно например visit(st,isfull(st));, но тогда visit не нужна. можно еще немножко разьяснений сути проблемы? и интересно это все абстрактно для саморазвития или задание носит прикладной характер?
вот я тут что то сделал ради примера, надеюсь поможет.
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
#include <iostream>
#include <string>
 
using namespace std;
 
class A{
    string str;
public:
    A(string s):str(s){}
    void print()
    {
        cout << str << '\n';
    }
};
class B{
    A a;
public:
    B(string s):a(s){}
    void mutate(A &mutant)
    {
        a=mutant;
    };
    void print()
    {
        a.print();
    }
    template <typename func> void visit(func f,A& object)
    {
        ((*this).*f)(object);
    }
    template <typename func> void visit(func f)
    {
        ((*this).*f)();
    }
};
int main()
{
    B b("str1");
    b.visit(&B::print);
    A a("test string");
    b.visit(&B::mutate,a);
    b.visit(&B::print);
    return 0;
}
1
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
14.07.2010, 04:12
Привет! Вот еще темы с ответами:

Как реализовать передачу массива в функцию и возвращение массива из функции? - C++
Нужно сделать отдельный блок программы в виде функции, которая в качестве аргумента должна принимать массив и возвращать массив после...

Описать функцию, формирующую словарь данного текста в виде массива слов - C++
Дан текст (2-3 строки) в файле F1. Текст состоит из слов, отделённых друг от друга пробелами или сочетанием символов &quot;точка пробел&quot;....

Напишите функцию для обмена строк двумерного массива и с ее помощью отсортируйте массив с элементами третьего столбика - C++
Помогите,пожалуйста,написать функцию.Вот задание: Напишите функцию для обмена строк двумерного массива и с ее помощью отсортируйте массив...

Написать функцию, которая заполняет список из массива - C++
Здравствуйте, нужно создать функцию которая заполняет список из массива, но строить список с конца, не могу вернутся к предыдущему елементу...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru