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

По зарплате поразрядной сортировкой от младшего разряда к старшему

17.05.2018, 18:08. Показов 998. Ответов 1
Метки нет (Все метки)

Сортировка не работает. Помогите найти ошибку.

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
//3
 
 
#include <iostream>
#include <fstream>
#include <string>
 
using namespace std;
 
ifstream in("in.txt");
ofstream out("out.txt");
 
 
 
struct people
{
    string F, Dol, DataBoth;
    int Staj, zp;
};
 
 
people *inFile(int &n)
{
    people *p = new people[n];
 
    for (int i = 0; i < n; i++)
    {
        in >> p[i].F >> p[i].Dol >> p[i].DataBoth >> p[i].Staj >> p[i].zp;
 
    }
    return p;
}
 
void sort_por(people *p, int n)
{
    int r = 1, max;
    max = p[0].zp;
    for (int i = 1; i < n; i++)
        if (max < p[i].zp) max = p[i].zp;
    while (max != 0)
    {
        r++;
        max /= 10;
    }
 
    people **mas = new people*[n];
    for (int i = 0; i < n; i++)
        mas[i] = new people[10];
    int *count = new int [10];
    for (int i = 0; i < 10; i++)
        count[i] = 0;
    int cif;
    for (int i = 0; i < r; i++)  //массив по разрядам
    {
        for (int j = 0; j < n; j++)  //считываются все числа
        {
            cif = (int)(p[j].zp / pow(10.0, i)) % 10;  //выделяется разряд
            mas [count[cif]] [cif] = p[j];  //распределили по карманам
        }
 
        int m = 0;
        for (int j = 0; j < n; j++)
            for (int k = 0; k < count[j]; k++)
            {
                p[m] = mas [k][j];
                m++;
            }
            for (int j = 0; j < 10; j++)
                count [j] = 0;
    }}
 
int main ()
{
    int n;
    in >> n;
    people *p = inFile(n);
    sort_por(p, n);
    for (int i = 0; i < n; i++, out << endl)
        out << p[i].F << " " << p[i].Dol << " " << p[i].DataBoth << " " << p[i].Staj << " " << p[i].zp;
    return 0;
}
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
17.05.2018, 18:08
Ответы с готовыми решениями:

помогите с поразрядной сортировкой
необходимо отсортировать методом поразрядной сортировки слова естественного языка.никак не...

Проблемы с поразрядной сортировкой msd
#include &lt;cstdlib&gt; #include &lt;iostream&gt; #include &lt;clocale&gt; using namespace std; int main(int...

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

Вывести цифры младшего и старшего разряда
Условие: Написать программу. Дано n-значное число longint. Провести с ним действия согласно номеру...

1
446 / 332 / 172
Регистрация: 01.07.2015
Сообщений: 1,162
17.05.2018, 18:39 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
// Поразрядная сортировка от младшего разряда к старшему.
void lsd_sort(vector<Worker> &data) noexcept {
  int n(static_cast<int>(data.size()));
 
  // Основание системы счисления.
  int p(10);
 
  // Максимальное кол-во разрядов
  int k(0);
 
  // Поиск максимального кол-ва разрядов.
  for (const auto &i : data) {
    size_t temp(i.GetSalary());
 
    int temp_k(0);
 
    while (temp != 0) {
      temp /= 10;
 
      ++temp_k;
    }
 
    k = max(k, temp_k);
  }
 
  // Для удобства степени p можно вынести в массив.
  vector<size_t> p_degrees(k, 1);
 
  // Подсчет степеней p.
  for (int i(1); i < k; ++i)
    p_degrees[i] = p_degrees[i - 1] * p;
 
  // Массив, куда бы будем записывать отсортированные данные.
  vector<vector<Worker>> temp(p);
 
  // Ходить будем ровно k раз, чтобы охватить все разряды.
  for (int i(0); i < k; ++i) {
    // Заполнение нашего временного массива соответствующими данными.
    // Из каждой зарплаты мы берем определенную цифру и в зависимости от нее
    // пишем нашего работника в одну из девяти "корзин". То есть в векторе с
    // индексам от 0 до 9 содержатся наши записи, которые мы поместили туда
    // из-за текущей цифры.
    // Индекс 0 - цифра 0.
    // Индекс 1 - цифра 1 и т.д.
    for (int j(0); j < n; ++j)
      temp[(data[j].GetSalary() / p_degrees[i]) % p].push_back(data[j]);
 
    // Теперь осталось переписать наши вычисления в исходный массив, чтобы по
    // текущему разряду было все отсортированно.
    for (int j(0), q(0); j < p; ++j) {
      // Собственно, запись в исходный массив.
      for (const auto &z : temp[j])
        data[q++] = z;
 
      // Нужно не забыть отчистить.
      temp[j].clear();
    }
  }
}
Сделайте под свою программу
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.05.2018, 18:39
Помогаю со студенческими работами здесь

Дано n-значное число longint. Вывести цифры младшего и старшего разряда
Написать программу. Дано n-значное число longint. Провести с ним действия согласно номеру варианта...

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

Напишите программу, считающую сумму старшего и младшего разряда заданного с клавиатуры целого числа.
Напишите программу, считающую сумму старшего и младшего разряда заданного с клавиатуры целого числа.

Число. Вывести только цифры самого младшего и самого старшего разряда
Дано n-значное целое число введеное с клавиатуры. Вывести только цифры самого младшего и самого...


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

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

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