0 / 0 / 5
Регистрация: 20.12.2016
Сообщений: 152
1

Поиск по возрасту в векторе структур

17.05.2017, 01:30. Показов 740. Ответов 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
#include <iostream>
#include <string>
#include <vector>
using namespace std;
 
class PhoneBock
{
public:
  string name;
  int phone;
  int age;
  PhoneBock()
  {
    name = "name";
    phone = 0;
    age = 0;
  }
};
vector<PhoneBock> s;
 
int main()
{
 
    cout << "To create a new contact push 1 "<< endl;
    cout << "Display all contacts push 2 "<< endl;
    cout << "Delete all contacts push 3 "<< endl;
    cout << "EXIT push 0 "<< endl;
    int a;
    cin >>a;
    while (a != 0)
    {
    cin >>a;
    if ( a == 1)
    {   
        string z;
        int x,c;
        cin >> z;
        cin >> x;
        cin >> c;
        PhoneBock b;
        b.name = z;
        b.phone = x;
        b.age = c;
        s.push_back (b); 
        for (int f = 0; f < s.size(); f++)
        { 
            cout <<"Phone Name "<< s[f].name << " " <<"Phone "<< s[f].phone << " " <<"Age "<< s[f].age << '\n';
          }
        }
        if (a == 2)
        {
       
            for (int r = 0; r < s.size(); r++)
        { 
            cout <<"Phone Name "<< s[r].name << " " <<"Phone "<< s[r].phone << " " <<"Age "<< s[r].age << '\n';
        } 
        }
        if (a == 3)
        {
            int p;
            cout<<"Please age ";
            cin>>p;
            for (int g = 0;g<s.size();g++)
            {
                if (s[g] == p)
                for( int i= 0;i<s.size();i++)
                {
                      cout <<"Phone Name "<< s[i].name << " " <<"Phone "<< s[i].phone << " " <<"Age "<< s[i].age << '\n';
                }
        }
        }
    }
}
вот через эту часть кода пытаюсь организовать поиск
C++
1
2
3
4
5
6
7
8
9
10
11
12
        if (a == 3)
        {
            int p;
            cout<<"Please age ";
            cin>>p;
            for (int g = 0;g<s.size();g++)
            {
                if (s[g] == p)
                for( int i= 0;i<s.size();i++)
                {
                      cout <<"Phone Name "<< s[i].name << " " <<"Phone "<< s[i].phone << " " <<"Age "<< s[i].age << '\n';
                }
подскажите что не так?
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.05.2017, 01:30
Ответы с готовыми решениями:

Сортировка массива структур по возрасту
Добрый день, помогите пожалуйста сделать сортировку по возрасту. Все методы пробовал нечего не...

Поиск по номеру квартиры и возрасту
Создать программу, которая обеспечивает ввод данных, вывод данных, поиск по номеру квартиры и...

Cтруктура СОТРУДНИК. Поиск по возрасту
Описать запись с именем sotrudnik, содержащую следующие поля: - фамилия, имя сотрудника; - стаж...

Java stream поиск по возрасту во вложенных списках
Как в одну строчку написать stream, который найдет из списка страны в котором есть список людей,...

2
nd2
3431 / 2810 / 1249
Регистрация: 29.01.2016
Сообщений: 9,426
17.05.2017, 02:05 2
Цитата Сообщение от swswsss Посмотреть сообщение
подскажите что не так?
Цитата Сообщение от swswsss Посмотреть сообщение
C++
1
if (s[g] == p)
C++
1
if (s[g].age == p)
Добавлено через 4 минуты
C++
1
2
3
4
5
            for (int g = 0; g < s.size(); g++)
            {
                if (s[g].age == p)
                     cout <<"Phone Name "<< s[q].name << " " <<"Phone "<< s[q].phone << " " <<"Age "<< s[q].age << '\n';
            }
0
0 / 0 / 5
Регистрация: 20.12.2016
Сообщений: 152
18.05.2017, 02:45  [ТС] 3
Цитата Сообщение от swswsss Посмотреть сообщение
сделал программу телефонную книгу
есть добавление контактов
вывод контактов
пытаюсь сделать поиск по возрасту
вот сама программа
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
#include <iostream>
#include <string>
#include <vector>
using namespace std;
 
class PhoneBock
{
public:
  string name;
  int phone;
  int age;
  PhoneBock()
  {
    name = "name";
    phone = 0;
    age = 0;
  }
};
vector<PhoneBock> s;
 
int main()
{
 
    cout << "To create a new contact push 1 "<< endl;
    cout << "Display all contacts push 2 "<< endl;
    cout << "Delete all contacts push 3 "<< endl;
    cout << "EXIT push 0 "<< endl;
    int a;
    cin >>a;
    while (a != 0)
    {
    cin >>a;
    if ( a == 1)
    {   
        string z;
        int x,c;
        cin >> z;
        cin >> x;
        cin >> c;
        PhoneBock b;
        b.name = z;
        b.phone = x;
        b.age = c;
        s.push_back (b); 
        for (int f = 0; f < s.size(); f++)
        { 
            cout <<"Phone Name "<< s[f].name << " " <<"Phone "<< s[f].phone << " " <<"Age "<< s[f].age << '\n';
          }
        }
        if (a == 2)
        {
       
            for (int r = 0; r < s.size(); r++)
        { 
            cout <<"Phone Name "<< s[r].name << " " <<"Phone "<< s[r].phone << " " <<"Age "<< s[r].age << '\n';
        } 
        }
        if (a == 3)
        {
            int p;
            cout<<"Please age ";
            cin>>p;
            for (int g = 0;g<s.size();g++)
            {
                if (s[g] == p)
                for( int i= 0;i<s.size();i++)
                {
                      cout <<"Phone Name "<< s[i].name << " " <<"Phone "<< s[i].phone << " " <<"Age "<< s[i].age << '\n';
                }
        }
        }
    }
}
вот через эту часть кода пытаюсь организовать поиск
C++
1
2
3
4
5
6
7
8
9
10
11
12
        if (a == 3)
        {
            int p;
            cout<<"Please age ";
            cin>>p;
            for (int g = 0;g<s.size();g++)
            {
                if (s[g] == p)
                for( int i= 0;i<s.size();i++)
                {
                      cout <<"Phone Name "<< s[i].name << " " <<"Phone "<< s[i].phone << " " <<"Age "<< s[i].age << '\n';
                }
подскажите что не так?
спасибо не знал
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
18.05.2017, 02:45
Помогаю со студенческими работами здесь

Односвязный (двусвязный) список - поиск людей по минимальному и максимальному возрасту
Здравствуйте форумчане. Имеется задание: Для структуры из Вашего варианта работы 6 сформировать...

Поиск в векторе
List&lt;Rest&gt; listrest = new List&lt;Rest&gt;(5); Log logs = new Log; Rest fff =...

Поиск в векторе
Есть вектор v Нужно задать поиск значения 6 и присвоить переменной i номер элемента вектора v, в...

Поиск в векторе
Есть вектор v: v = 0; v = 1; v = 2; v = 4; v = 6; Как с помощью алгоритма find узнать...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru