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

Проверить, есть ли в массиве заданный елемент

20.11.2019, 16:01. Показов 498. Ответов 8

В кейсе 3 мне нужно вывести информацию про рабочего который работает в подразделении, название которого вводиться с клавиатуры или сообщить, що рабочих в таком подразделении нет. Как реализовать эту проверку

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
#include <iostream>
#include <string>
#include <algorithm>
#include <iterator>
#include <conio.h>
#include <vector>
#include <fstream>
using namespace std;
 
struct w {
    string sname;       //Фамилия
    string name;
    string fname;       //Отчество
    string gname;       //Название подразделения
    int lateness;
};
 
ostream& operator << (ostream& os, const w& st) 
{
    return os << st.sname << " " << st.name << " " << st.fname << " [" << st.gname << "]" << " - " << st.lateness;
}
 
vector<w> input()
{
    int j = 0;
    cin >> j;
    vector<w> vec(j);
 
    for (int i = 0; i < j; i++)
    {
        cout << "FIB:  \t\t";
        cin >> vec[i].sname;
        cin >> vec[i].name;
        cin >> vec[i].fname;
 
        cout << "Group name: \t";
        cin >> vec[i].gname;
 
        cout << "Lateness: \t";
        cin >> vec[i].lateness;
 
        cin.get();
        cout << "\n";
    }
 
    return vec;
}
 
int main()
{
    vector<w> vec = input();
    int oper;
    cout << "1. Sort by surname\n" << "2. Sort by lateness\n" << "4. Quit\n";
    cin >> oper;
    string check;
    do
    {
        switch (oper) {
 
        case 1:
            // Сортировка по фамилии
            cout << "\nsorting by Surname\n";
            sort(vec.begin(), vec.end(), [](w lh, w rh) { return lh.sname < rh.sname; });
            copy(vec.begin(), vec.end(), ostream_iterator<w>(cout, "\n"));
            cout << endl;
            break;
        
        case 2:
            // Сортировка по убывание продолжительности опоздания
            cout << "sorting by lateness\n";
            sort(vec.begin(), vec.end(), [](w lh, w rh) { return lh.lateness > rh.lateness; });
            copy(vec.begin(), vec.end(), ostream_iterator<w>(cout, "\n"));
            cout << endl;
            break;
        
        case 3:
            cout << "Input group name to check";
            cin >> check;
            
        case 4:
            cout << "Quiting...\n";
            exit(0);
        }
    } while (true);
    
    
    return 0;
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
20.11.2019, 16:01
Ответы с готовыми решениями:

Проверить, есть ли в реестре заданный ключ
Кокой функцией можно проверить, есть ли в реестре ключ?

Проверить, есть ли в массиве положительные элементы и если есть, то найти среди них максимальный
задан одном. массив из N чисел. нужно проверить есть ли в массиве положительные элементы и если...

Массив: проверить, существует ли в массиве $ar2 элемент, который есть в массиве $ar1.
Есть два массива $ar1 = array(1,5,9,10,100); $ar2 = array(1,2,3,4,6); Надо проверить, существует...

Проверить, есть ли в массиве A[n] числа B и C и определить, какое из чисел встречается в массиве чаще
Проверить, есть ли в массиве A числа B и C и определить, какое из чисел встречается в массиве чаще

8
фрилансер
4169 / 3579 / 797
Регистрация: 11.10.2019
Сообщений: 9,615
20.11.2019, 18:01 2
попробуй
C++
1
2
3
4
5
6
7
8
9
10
            case 3:
            {
                cout << "Input group name to check";
                cin >> check;
                auto found=std::find_if(vec.begin(), vec.end(),[&check](const auto& item){return item.name==check;});
                if(found!=vec.end())
                {
                    //нашли
                }
            }break;
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
20.11.2019, 19:28  [ТС] 3
как мне вывести информацию про рабочего который состоит в подразделении введенном с клавиатуры в поли if

Добавлено через 1 минуту
помогите пожалуйста
0
фрилансер
4169 / 3579 / 797
Регистрация: 11.10.2019
Сообщений: 9,615
20.11.2019, 19:30 4
hazard11, found - это нужный итератор, выводи из него
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
20.11.2019, 19:41  [ТС] 5
можете показать на этом конкретном примере пожалуйста, я просто пока что только разбираю с++, и не очень ориентуруюсь,
как выводить с итератора
0
фрилансер
4169 / 3579 / 797
Регистрация: 11.10.2019
Сообщений: 9,615
20.11.2019, 19:42 6
C++
1
cout << found->sname
и так далее
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
20.11.2019, 19:57  [ТС] 7
не работает, посмотрите что выводить на фотке, не понимаю почему не выводит данные по рабочему той групи которую ввели с клавиатуры
Миниатюры
Проверить, есть ли в массиве заданный елемент  
0
фрилансер
4169 / 3579 / 797
Регистрация: 11.10.2019
Сообщений: 9,615
20.11.2019, 20:01 8
hazard11, тогда отладчик в руки и разбирайся, что где не так заполнилось
0
0 / 0 / 0
Регистрация: 10.10.2019
Сообщений: 22
20.11.2019, 20:43  [ТС] 9
прошелся откладчиком, все заполняется как нужно, не понимаб в чем ошыбка, помогите пожалуйста

Добавлено через 27 минут
все спасибо, разобрался, работает

Добавлено через 29 секунд
можете удалять пост, сделано
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
20.11.2019, 20:43
Помогаю со студенческими работами здесь

Проверить есть ли в массиве A [n] числа B и C и определить какое из чисел встречается в массиве чаще
проверить есть ли в массиве A числа B и C и определить какое из чисел встречается в массиве чаще

Проверить, есть ли в массиве А [n] числа В и С и определить, какое из чисел встречается в массиве чаще
1. Проверить, есть ли в массиве А числа В и С и определить, какое из чисел встречается в массиве...

Проверить, есть ли в одномерном массиве X, A(n) и B(n) одинаковые элементы, если есть, то найти среди них наибольший
Проверить, есть ли в одномерном массиве X, A(n) и B(n) одинаковые элементы, если есть, то найти...

Проверить, есть ли слово в массиве
Нужна помощь. Вообщем , есть символьный массив , пользователь вводит слово и нужно проверить есть...


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

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

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