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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
Тангенс
1 / 1 / 0
Регистрация: 19.07.2013
Сообщений: 121
#1

Алгоритмом быстрой сортировки строк - C++

07.05.2014, 21:19. Просмотров 312. Ответов 1
Метки нет (Все метки)

Необходимо отсортировать дату,она же char, по возрастанию.

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
void q_sort(Medicament m[], int f, int l){
 
  int i = f, j = l;
  char *mid = m[(f + l) / 2].form;
 
  while(i <= j) {
      while(strcmp(m[i].form, mid) < 0)
        i++;
      while(strcmp(mid, m[j].form) > 0)
        j--;
    if(j<=i) {
      char *tmp = m[i].form;
      strcpy(m[j].form, m[i].form);
      strcpy(m[i].form, tmp);
      i++;
      j--;
    }
  }
 
  if (f < j)
    q_sort(m, j, f);
  if (i < l)
     q_sort(m, i, l);
}
Алгоритм не работает

Полный код

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
#include <iostream>
#include <conio.h>
#include <ctime>
 
using namespace std;
 
const int N = 10;
 
struct Medicament{
    int num;
    char* name;
    char form[20];
    int price;
 
    // условие хранения
    int day;
    int mounth;
    int year;
};
 
void fill(Medicament m[]){
    for(int i=0;i<N;i++){
        m[i].num = rand()%100 + 200;
        
        m[i].day = rand()%29+1;
        m[i].mounth = rand()%12+1;
        m[i].year = rand()%44+1970;
 
        sprintf(m[i].form,"%d.%d.%d",m[i].day,m[i].mounth,m[i].year);
    }
}
 
 
void q_sort(Medicament m[], int f, int l){
 
  int i = f, j = l;
  char *mid = m[(f + l) / 2].form;
 
  while(i <= j) {
      while(strcmp(m[i].form, mid) < 0)
        i++;
      while(strcmp(mid, m[j].form) > 0)
        j--;
    if(j<=i) {
      char *tmp = m[i].form;
      strcpy(m[j].form, m[i].form);
      strcpy(m[i].form, tmp);
      i++;
      j--;
    }
  }
 
  if (f < j)
    q_sort(m, j, f);
  if (i < l)
     q_sort(m, i, l);
}
 
void print(Medicament m[]){
    for(int i=0;i<N;i++){
        cout<<"Дата лекарства "<<' '<<m[i].form<<endl;
    }
}
 
void main(){
 
    setlocale(LC_ALL,"rus");
 
    Medicament m[N];
 
    fill(m);
 
    print(m);
    cout<<endl<<endl;
 
    q_sort(m,0,N);
    print(m);
 
    _getch();
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
07.05.2014, 21:19     Алгоритмом быстрой сортировки строк
Посмотрите здесь:

Пример быстрой сортировки массива строк и сортировки методом выбора - C++
Добрый вечер. Скиньте пожалуйста пример быстрой сортировки массива строк и сортировки массива строк методом выбора. Очень срочно надо,...

Визуализатор быстрой сортировки - C++
Добрый день! Нужно написать программу, которая иллюстрирует работу быстрой сортировки. В частности должно присутствовать: *вывод...

Не алгоритм быстрой сортировки - C++
Просто как подключить эту функцию Не работаеееет #include&lt;iostream&gt; #include&lt;iomanip&gt; #include &lt;algorithm&gt; using namespace std; ...

Иллюстрация быстрой сортировки - C++
Ребят,необходимо написать программу похожую на ту,которая тут http://www.cyberforum.ru/csharp-beginners/thread874724.html Помогите...

Алгорим быстрой сортировки - C++
В одной из тем выложен алгоритм быстрой сортировки. Возник вопрос: если индексы i и j указывают на один элемент зачем нужен обмен? ...

Алгоритм быстрой сортировки - C++
Написать программу, реализующую алгоритм быстрой сортировки(рекурсивный) для массива целых чисел.

Вывод результата быстрой сортировки - C++
Доброго времени суток, возникла проблема с быстрой сортировкой, не знаю как реализовать вывод отсортированного массива. Сам код: #include...

Найти ошибку быстрой сортировки - C++
Пытался написать, помогите найти ошибки. Код должен вставит на первое место самое большое четное число из списка и дальше сортировать...

Вопросы насчёт быстрой сортировки - C++
Здравствуйте. Объясните, пожалуйста. Есть алгоритм быстрой сортировки: Код: int shag=1; void quickSort(int arr, int left, int...

Поиск самой быстрой сортировки - C++
Ищу быструю реализацию быстрого алгоритма сортировки массива для среднего случая на С/С++ под Win32. Остальные параметры не имеют значения....


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
XRuZzz
Антикодер
649 / 550 / 27
Регистрация: 15.09.2012
Сообщений: 2,497
07.05.2014, 22:08     Алгоритмом быстрой сортировки строк #2
а если на основе кода вики сделать? Быстрая сортировка
Или вы хотите ошибку найти?

QuickSort - более понятное разъяснение алгоритма

там же в видео реализация на C++

викиучебник с реализациями на всех языках

сортировать символы это выстрел себе в ногу, надо адаптировать алгоритм для чисел

для сортировки даты лучше взять класс Date из книги Страуструпа "The С++ Programming Language"
перегрузить у него операторы сравнения, для того чтоб можно было сортировать дату в более удобном виде.
Правда для новичков это сложновато.
Yandex
Объявления
07.05.2014, 22:08     Алгоритмом быстрой сортировки строк
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru