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

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

Войти
Регистрация
Восстановить пароль
 
VladosLancer
1 / 1 / 0
Регистрация: 03.10.2011
Сообщений: 96
#1

Определите структуру Pair – пара «имя = значение» - C++

09.01.2013, 14:20. Просмотров 919. Ответов 2
Метки нет (Все метки)

Здравствуйте. Вот задание:
Определите структуру Pair – пара «имя = значение» и структуру Pairs – массив пар:
C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
struct Pair
 
{
 
    char * name;    //имя
 
    int value;  //значение
 
};
 
#define MAX_PAIRS 100
 
struct Pairs
 
{
 
    Pair p[MAX_PAIRS];  //массив пар
 
    int count;      //количество пар в массиве
 
};
Определите следующие функции для работы с массивом:

int GetValue(Pairs* p, char* name, int* var); // получить значение для заданного имени (функция должна возвратить 0 если нет такого имени и 1 в случае успеха, а значение возвращать через второй параметр функции);

void SetValue(Pairs* p, char* name, int value); // установить значение для заданного имени (если такого имени в массиве нет, то добавить в массив новую пару);

void PrintPairs(Pairs* p); – вывод всех пар на экран.

Непонятия у меня с первой функцией... все остальные я написал...
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
#include <iostream>
#include <conio.h>
struct Pair
{
    char * name;    //имя
    int value;  //значение
};
#define MAX_PAIRS 100
struct Pairs
{
    Pair p[MAX_PAIRS];  //массив пар
    int count;      //количество пар в массиве
};
int GetValue(Pairs  *t, char *name, int *var)
{ // что здесь писать немного в заблуждении
}
 
void SetValue(Pairs* t, char* name, int value) 
{   bool flag=true;     
    for (int i = 0; i < t->count; i++ )
        {if (t->p[i].name == name)
            {t->p[i].value = value; 
            flag = false; break;}
    if (flag == true)
    {
        t->p[t->count].name = name;
        t->p[t->count].value = value;
        t->count++;
    }
}
}
void PrintPairs(Pairs* p) 
{
    for (int i = 0; i < p->count; i++)
    {
        std::cout<< p->p[i].name;
        std::cout<< p->p[i].value<<"\n";
    }
}
 
int main (){
Pairs d,*a;
d.count=1;
d.p[0].name = "lolooo";
d.p[0].value = 25;
a=&d;
SetValue(a,"lol",40);
PrintPairs(a);
getch();
return 0;
}
эти строки
C++
1
2
3
4
d.count=1;
d.p[0].name = "lolooo";
d.p[0].value = 25;
a=&d;
я написал для проверки работы программы...
помогите, пожалуйста, разобраться с первой функцией... тобишь разъясните что куда и после чего и сколько... как реализовать...
Лучшие ответы (1)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
09.01.2013, 14:20
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Определите структуру Pair – пара «имя = значение» (C++):

Создать класс Pair (пара чисел) - C++
Создать класс Pair (пара чисел). Пара должна быть представлено двумя полями: типа int для первого числа и типа double для второго. Первое...

Создайте класс Pair (пара чисел); - C++
Добрый день. Задали задание : Создайте класс Pair (пара чисел); определите метод перемножения полей и операцию сложения пар (а, b) +...

Создать класс pair (пара чисел) - C++
создать класс pair (пара чисел); определить метод перемножения полей и операцию сложения пар (a,b)+(c,d) =(a+b,c+d) .определить производный...

Создать класс Pair(пара чисел) и класс-наследник Fraction - C++
Создать класс Pair (пара чисел); определить методы изменения полей и сравнения пар: пара p1 больше пары p2, если (first.p1&gt;first.p2) или...

Создать класс Pair (пара чисел); определить методы изменения полей и вычисления произведения чисел. - C++
Создать класс Pair (пара чисел); определить методы изменения полей и вычисления произведения чисел. Определить производный класс Rectangle...

Реализовать пользовательский класс Pair (упрощённый аналог std::pair) - C++
Здравствуйте. Проблема с выводом. В приложенном задании, требуется сделать вывод как в примере. Мой вывод основан на вводе количества...

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
rangerx
1933 / 1542 / 141
Регистрация: 31.05.2009
Сообщений: 2,912
09.01.2013, 18:45 #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
#include <iostream>
#include <cstring>
 
struct Pair
{
    char* name; //имя
    int value;  //значение
};
 
#define MAX_PAIRS 100
 
struct Pairs
{
    Pair items[MAX_PAIRS];  //массив пар
    int count;              //количество пар в массиве
};
 
// создаёт в куче копию строки src и возвращает на неё указатель 
char* StrDup(const char* src)
{
    char* dest = new char[std::strlen(src) + 1];
    return std::strcpy(dest, src);
}
 
int GetValue(const Pairs *p, const char *name, int *var)
{ 
    for (int i = 0; i < p->count; i++)
    {
        // сравниваем строки с помощью функции strcmp(если она возвращает 0, то строки равны)
        if(std::strcmp(p->items[i].name, name) == 0)
        {
            // помещаем найденное значение в переменную адрес которой хранит переменная var
            *var = p->items[i].value; 
            
            // найдено
            return 1; 
        }
    }
    
    return 0; // не найдено
}
 
void SetValue(Pairs* p, const char* name, int value) 
{       
    for (int i = 0; i < p->count; i++)
    {
        // сравниваем строки с помощью функции strcmp(если она возвращает 0, то строки равны)
        // условие вида if(p->items[i].name == name) сравнит указатели(адреса), а не строки
        if (std::strcmp(p->items[i].name, name) == 0)
        {
            p->items[i].value = value; 
            return; // и никаких flag'ов
        }        
    }
    
    p->items[p->count].name = StrDup(name);
    p->items[p->count].value = value;
    p->count++;
}
 
void PrintPairs(const Pairs *p) 
{
    for (int i = 0; i < p->count; i++)
    {
        std::cout << p->items[i].name << " -> ";
        std::cout << p->items[i].value << "\n";
    }
}
 
void Init(Pairs *p)
{
    p->count = 0;
}
 
void Free(Pairs *p)
{
    for (int i = 0; i < p->count; i++)
        delete[] p->items[i].name;
}
 
int main ()
{
    Pairs d;
    Init(&d);
        
    SetValue(&d, "lolooo", 25);            
    SetValue(&d, "lol" , 40);    
    
    PrintPairs(&d);
    
    //-----
    
    int value;
    
    if(GetValue(&d, "lol", &value) == 0)    
        std::cout << "not found\n";        
    else    
        std::cout << value << "\n";    
    
    //-----
    
    SetValue(&d, "lol" , 10);        
    PrintPairs(&d);    
    
    Free(&d);
}
VladosLancer
1 / 1 / 0
Регистрация: 03.10.2011
Сообщений: 96
09.01.2013, 20:57  [ТС] #3
Большое спасибо, а то даже в голову не приходило как реализовать
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
09.01.2013, 20:57
Привет! Вот еще темы с ответами:

Определите структуру с именем - C++
1)Определите структуру с именем ticket и полями vagon, mesto (в ней хранятся данные о номере вагона и месте). 2)Определите структуру с...

Как считать данные в vector<pair<int, pair<int, int>>> arr(m) ? - C++
Здравствуйте! Помогите, как считать данные данные в массив такого типа? vector&lt;pair&lt;int, pair&lt;int, int&gt;&gt;&gt; arr(m) Пытался вот так...

Определите структуру Complex для хранения комплексных чисел - C++
Условия задачи: Определите структуру Complex для хранения комплексных чисел: struct Complex { double re; //вещественная...

Определите структуру Complex для хранения комплексных чисел - C++
Не могу осилить задание, помогите! Определите структуру Complex для хранения комплексных чисел: struct Complex { ...


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

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

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