Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
0 / 0 / 0
Регистрация: 11.01.2013
Сообщений: 12

Структуры: ввести данные о работниках и вывести их данные, отсортированные по алфавиту

31.01.2015, 00:56. Показов 2000. Ответов 3
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Всем привет! Подскажите пожалуйста, что не так с моей функцией proverka?
Мне нужно ввести данные о работниках и вывести их данные, отсортированные по алфавиту.
Ф-ция работает неправильно при условии, что первый символ фамилии работника совпадает с первым символом сравниваемого работника

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
#include <iostream>
#include <math.h>
 
struct employee{
    employee() {};
    char surname[30];
    char p_numb[14];
};
 
void proverka(char a[30], char b[30], int &counter, int x){
    if (a[x] == b[x]){
        x++;
        proverka(a, b, counter, x);
    }
    if (a[x] > b[x]){
        counter++;
    }
};
 
void worker_reg(employee &w){
    memset(w.surname, 0, 30);
    memset(w.p_numb, 0, 14);
    std::cout << "Vvedite familiyu:";
    std::cin >> w.surname;
    std::cout << "Vvedite nomer telefona:";
    std::cin >> w.p_numb;
    std::cout << std::endl;
};
 
int main(){
    employee tmp;
    int n, pos;
    std::cout << "Vvedite dannie sotrudnikov" << std::endl;
    std::cout << "Kolichestvo sotrudnikov: ";
    std::cin >> n;
    std::cout << std::endl;
    employee *worker = new employee[n];
    employee *sort_worker = new employee[n];
    for (int i = 0; i < n; i++){
        memset(sort_worker[i].surname, 0, 30);
        memset(sort_worker[i].p_numb, 0, 14);
    }
    for (int i = 0; i < n; i++){
        worker_reg(worker[i]);
    }
    for (int i = 0; i < n; i++){
        tmp = worker[i];
        pos = 0;
        for (int j = 0; j < n; j++){
            if (tmp.surname == worker[j].surname){
                if (tmp.p_numb != worker[j].p_numb){
                    proverka(tmp.p_numb, worker[j].p_numb, pos, 0);
                }
            }
            proverka(tmp.surname, worker[j].surname, pos, 0);
        }
        sort_worker[pos] = tmp;
    }
    for (int i = 0; i < n; i++){
        std::cout << sort_worker[i].surname << std::endl << sort_worker[i].p_numb << std::endl;
        std::cout << std::endl;
    }
    delete []worker;
    delete []sort_worker;
    system("PAUSE");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
31.01.2015, 00:56
Ответы с готовыми решениями:

Ввести в файл данные о пяти работниках и вывести в другой файл максимальный оклад
Задача на pascal abc,решить задачу используя type Помогите пожалуйста очень надо) Составить программу которая создает файл...

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

Вывести данные, отсортированные по заданному ключу
Ребят помогите переделать прогу сортировки Задание: Работа обязательно с файлами. В файле содержатся данные о сотрудниках...

3
7804 / 6568 / 2988
Регистрация: 14.04.2014
Сообщений: 28,705
31.01.2015, 09:07
А что вообще делает эта функция, зачем там рекурсия и почему не учитывается достижение конца строки?
Что в строке 50, может там strcmp() нужно использовать? И что такое pos? В функции это индекс символа, в программе - индекс массива работников.
0
 Аватар для 1XPLoade1
30 / 30 / 38
Регистрация: 23.01.2015
Сообщений: 174
31.01.2015, 10:37
По-моему так:
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
#include <iostream>
#include <math.h>
 
struct employee{
    employee() {};
    char surname[30];
    char p_numb[14];
};
 
bool proverka(char a[30], char b[30], int x)
{
    if (a[x] != b[x] && x >= 0)
        return false;
    
    if (a[x] == b[x] && x >= 0) {
        x--;
        if (x < 0) return true;
        return proverka(a, b, x);
    }
 
    return true;
}
 
template<typename T>void swap(T& t1, T& t2)
 { T _tt = t1; t1 = t2; t2 = _tt; }
 
void worker_reg(employee &w){
    memset(w.surname, 0, 30);
    memset(w.p_numb, 0, 14);
    std::cout << "Vvedite familiyu:";
    std::cin >> w.surname;
    std::cout << "Vvedite nomer telefona:";
    std::cin >> w.p_numb;
    std::cout << std::endl;
};
 
int main(){
    int n;
    std::cout << "Vvedite dannie sotrudnikov" << std::endl;
    std::cout << "Kolichestvo sotrudnikov: ";
    std::cin >> n;
    std::cout << std::endl;
    employee *worker = new employee[n];
    for (int i = 0; i < n; i++){
        memset(worker[i].surname, 0, 30);
        memset(worker[i].p_numb, 0, 14);
    }
    for (int i = 0; i < n; i++){
        worker_reg(worker[i]);
    }
 
    for (int r = 0; r < 30; r++)
        for (int i = 0; i < n; i++)
        {
            char tmp = worker[i].surname[r];
            for (int j = i + 1; j < n; j++)
            if (tmp > worker[j].surname[r] &&
                proverka(worker[i].surname, worker[j].surname, r - 1))
                swap<employee>(worker[i], worker[j]);
        }
 
    for (int i = 0; i < n; i++){
        std::cout << worker[i].surname << std::endl << worker[i].p_numb << std::endl;
        std::cout << std::endl;
    }
    delete[]worker;
    system("PAUSE");
    return 0;
}
Миниатюры
Структуры:  ввести данные о работниках и вывести их данные, отсортированные по алфавиту  
1
0 / 0 / 0
Регистрация: 11.01.2013
Сообщений: 12
31.01.2015, 15:44  [ТС]
а что это за
C++
1
2
template<typename T>void swap(T& t1, T& t2)
 { T _tt = t1; t1 = t2; t2 = _tt; }
?
что она делает?

Добавлено через 8 минут
эта функция проводит проверку элементов строки surname.
pos - это некий аргумент, который увеличивается каждый раз, когда первая буква tmp.surname является меньше чем первая буква всех worker[j].surname. Этот pos нужен для определения, в какой ячейке массива sort_workers будет находится наш tmp.
Иными словами, чем чаще первый элемент будет младше проверочного элемента в ASCII, тем меньше pos и, следовательно, тем индекс массива sort_workers тоже будет меньше
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
31.01.2015, 15:44
Помогаю со студенческими работами здесь

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

Вывести данные о премированных работниках из файла на экран
Записать в файл данные о работниках предприятия(используя структуру), вывести данные о премированных работниках из файла на экран

Массивы записей: вывести данные о работниках в виде таблицы
Нужно вывести данные о работниках в виде таблицы. Данные водятся с клавиатуры. (Имя, адрес, номер паспорта, должность)

С помощью методов ввести данные, вывести данные из массива
Создать класс собак (название породы, возраст (больше двух лет), вес, средний вес породы, группа). В функции main создать массив собак трех...

Ввести данные четырех сотрудников и отсортировать их по алфавиту
Сделал программу для того, чтобы ввести 4 сотрудника и отсортировать их по алфавиту, но она не работает. Помогите пожалуйста. #include...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru