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

Отсортировать строки быстрой сортировкой - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Ошибка с присвоением значений к массивам http://www.cyberforum.ru/cpp-beginners/thread1165475.html
Значение функции дроби,не могу присвоить к массиву... не получается подсчет ..Помогите плиз..с этим кусочком.... Код: double drob(int a, int b) { return static_cast<double>(a)/b; } void...
C++ Найдите ошибки class ABC{ int a=3; int b; int c; public: ABC(int n=1) {b=n;} mul() {c=1+a*b;} }; http://www.cyberforum.ru/cpp-beginners/thread1165474.html
Найдите ошибку в классе C++
В классе PRIMER объявлен прототип int PRIMER(int a, float pi);
Списки(односторонний список со структурой) C++
Необходимо организовать односторонний список со структурой(код структуры ниже). Сделать следующие действия: 1) Добавление элементов в список; 2)Удаление элементов со списка; 3)Добавление элемента...
C++ Алгоритм Лемпела-Зивы. Программа не выходит из цикла http://www.cyberforum.ru/cpp-beginners/thread1165438.html
Данная программа реализует (почти) Алгоритм Лемпела-Зивы #include <vector> #include <string> #include <iostream> #include <fstream> #include <utility> #include <algorithm> using namespace...
C++ Выход из цикла Доброго времени суток. Подскажите, пожалуйста как сделать выход из цикла при нажатии 0 в меню. Пытался так на ESC, но не выходит. #include <iostream> #include <conio.h> //include library with... подробнее

Показать сообщение отдельно
Тангенс
1 / 1 / 0
Регистрация: 19.07.2013
Сообщений: 121

Отсортировать строки быстрой сортировкой - C++

04.05.2014, 01:37. Просмотров 128. Ответов 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
const int N = 10;
 
struct Medicament{
    int num;
    char* name;
    char form[20];
    int price;
 
    // условие хранения
 
    int day;
    int mounth;
    int year;
};
 
void q_sort(Medicament m[], int f, int l){
 
    int i = f, j = l;
    char *pivot = m[(f + l) / 2].form;
 
  // partition
  while (i <= j) {
      while (strcmp(m[i].form, pivot) < 0)
      i++;
      while (strcmp(pivot, m[j].form) < 0)
      j--;
    if (i <= j) {
      char *tmp = m[i].form;
      strcpy(m[i].form, m[j].form);
      strcpy(m[j].form, tmp);
      i++;
      j--;
    }
  };
 
  // recursion
  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);
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru