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

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

Восстановить пароль Регистрация
 
Тангенс
1 / 1 / 0
Регистрация: 19.07.2013
Сообщений: 121
07.05.2014, 21:19     Алгоритмом быстрой сортировки строк #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++
C++ Тонкости быстрой сортировки
C++ Алгорим быстрой сортировки
визуализатор быстрой сортировки С++ C++
прогресс выполнения быстрой сортировки C++
Алгоритм быстрой сортировки C++

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

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

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

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

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

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

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

Текущее время: 16:27. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru