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

поразрядная сортировка - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Разработать программу для работы с данными. Данные должны храниться в файле http://www.cyberforum.ru/cpp-beginners/thread1036476.html
Разработать программу для работы с данными. Данные должны храниться в файле. Предусмотреть создание меню со следующими пунктами: - ПРОСМОТР ВСЕХ ЗАПИСЕЙ; - ПОИСК ЗАПИСИ ПО ПАРАМЕТРУ; - СОГЛАСНО ВАРИАНТУ ЗАДАНИЯ; - РЕДАКТИРОВАНИЕ ЗАПИСИ; - УДАЛЕНИЕ ЗАПИСИ; - УДАЛЕНИЕ ВСЕХ ЗАПИСЕЙ; - ВЫХОД. Программа не должна завершаться после выполнения одного из пунктов меню.
C++ Вывести по байтам числа Подскажите, можно ли как нибудь, приспособить в мой код#include <iostream> #include <cstdio> #include <iomanip> #include <bitset> using namespace std; int main() { int i;float f;long int l;double d; char c; bool b; int *pi=&i; int *pf=&l; int *pl=&f; http://www.cyberforum.ru/cpp-beginners/thread1036466.html
C++ задача выпуклый многоугольник
выпуклый многоугольник. многоугольник задан координатами своих вершин при их последовательном обходе. Составить подпрограмму, определяющую, является ли многоугольник выпуклым.
Написать функцию, заменяющую n левых битов числа x на n правых инвертированных битов числа y C++
Написать функцию, заменяющую n левых битов числа x на n правых инвертированных битов числа y. Провести вычисление для заданных чисел x и y. Результат записать в файл.
C++ Функции для подсчёта количества слов в списке http://www.cyberforum.ru/cpp-beginners/thread1036428.html
Помогите в решении задачи по С++ нужно написать функции для подсчёта количества слов в списке: а) начинающихся и оканчивающихся одной и той же буквой. б)начинающихся с той же буквы. что и следующие слово. очень очень нужна помощь((((
C++ Определить количество «особых» элементов матрицы Всем привет. Тут вот задачка на динамический двумерный массив : Задана матрица размером NxM. Определить количество «особых» элементов матрицы, считая элемент «особым», если он больше суммы остальных элементов своего столбца. подробнее

Показать сообщение отдельно
alisska
2 / 2 / 0
Регистрация: 10.03.2013
Сообщений: 39

поразрядная сортировка - C++

10.12.2013, 21:55. Просмотров 186. Ответов 0
Метки (Все метки)

Помогите разобраться в этой сортировке, пожалуйста.( Каждый исходный массив должен обрабатываться подпрограммой сортировки с подсчетом и выводом фактического числа выполненных сравнений и пересылок. Поскольку каждый из универсальных методов выполняет сортировку “на месте”, т.е. изменяет исходный массив, то для наглядности работы можно передавать в подпрограмму сортировки копию исходного массива, объявив его как параметр-значение.)
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
#include <iostream>
#include <cstdlib>
using namespace std;
 
int *CreateAuto(int n)
{
if (n<=10000 && n>1) 
{ 
method=0; 
int *arr= new int [n]; 
for ( int i=0; i<n; i++) 
arr[i]=rand()%n; 
return arr; 
} 
else 
return NULL;
}
 
void Show(int *arr, int n)
{
cout << endl; 
for ( int i=0; i<n; i++) 
cout << arr[i] << " "; 
cout << endl;
}
 
void Copy(int *arr1, int *arr2, int n)
{
for ( int i=0; i<n; i++) 
arr2[i]=arr1[i];
}
 
struct ITEM {
int info; 
ITEM *next;
};
 
void AddItem(ITEM *pItem, int info)
{
while(pItem->next!=NULL) 
pItem=pItem->next; 
pItem->next = new ITEM; 
pItem->next->info=info; 
pItem->next->next=NULL;
}
 
void ClearList(ITEM *head)
{
while(head!=NULL) 
{ 
ITEM *tmp=head; 
head=head->next; 
delete tmp; 
}
}
 
void DigitSort(int *arr, int n)
{
ITEM *sort = new ITEM [10]; 
int k=n-1; 
int i=0; 
int moves=0; 
while(k>=1) 
{ 
i++; 
k/=10; 
for( int j=0; j<10; j++) 
sort[j].next=NULL; 
for ( int j=0; j<n; j++, moves++) 
{ 
int div=1; 
for ( int l=0;l<i;l++,div*=10); 
AddItem(&sort[((arr[j]%div)*10)/div],arr[j]); 
} 
for ( int j=0, l=0; l<n; j++) 
{ 
ITEM *tmp=sort[j].next; 
while(tmp!=NULL) 
{ 
arr[l]=tmp->info; 
tmp=tmp->next; 
l++; 
moves++; 
} 
} 
for( int j=0; j<10; j++) 
ClearList(sort[j].next); 
} 
Show(arr,n); 
cout << "Кол-во пересылок = " << moves << endl; 
delete[] sort;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru