С Новым годом! Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.67/9: Рейтинг темы: голосов - 9, средняя оценка - 4.67
0 / 0 / 2
Регистрация: 21.09.2010
Сообщений: 74
1

Замена функции qsort();

28.11.2010, 11:35. Показов 1728. Ответов 3
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Здравствуйте! Помогите, пожалуйста заменить стандартную функцию qsort(); на сортировку, которая будет сортировать массив структур. Так же проблема - программа сохраняет файл со статистикой в отдельный файл statistic.dat, но как его просмотреть? И ещё вопрос - Статистику программа выводит на экран, но выводит только имя пользователя и количество итераций - как сделать, чтобы выводило на экран ещё и введённый массив? Спасибо.
Вот код:
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
93
94
95
96
    #include <stdio.h>
        #include <stdlib.h>
        #include <string.h>
        #include <sys/stat.h>
        #define n 15
        static const char* filename = "statistic.dat";
 
       struct information {
        char user[32];
        int array[n];
        int iterations;
      };
  
      void sort(int* array, int* it) {
         int i, j;
         for(i = n - 1; i >= 1; i--) {
            for(j = 0; j < i; j++) {
               if(array[j] > array[j+1]) {
                  int foo = array[j];
                  array[j] = array[j+1];
                  array[j+1] = foo;
                  (*it)++;
               }
            }
         }
      }
  
      int compar(const void* a, const void* b) {
         struct information* _1 = (struct information*)a;
         struct information* _2 = (struct information*)b;
         return _1->iterations < _2->iterations;
      }
  
      int main() {
         int i;
         struct information info;
         info.iterations = 0;
         printf("vvedite imja polzovatelja\n");
         scanf("%s", info.user);
  
         printf("Bedute 15 elemeHtoB macuBa\n");
         for(i = 0; i < n; i++) {
            printf("mass[%d] = ", i);
            scanf("%d", &info.array[i]);
         }
         printf("\n");
  
         sort(info.array, &info.iterations);
  
         for(i = 0; i < n; i++) {
            printf("%4d ", info.array[i]);
         }
         printf("\n");
  
         FILE* file = fopen(filename, "rb");
         if ( !file ) {
            file = fopen(filename, "wb");
            if ( !file ) {
               fprintf(stderr, "can`t create file!");
               return 1;
            }
            fwrite(&info, sizeof(struct information), 1, file);
            fclose(file);
            return 0;
         } else {
            struct stat fileinfo;
            fstat(fileno(file), &fileinfo);
            int file_size = fileinfo.st_size;
            int structs = file_size/sizeof(struct information);
            struct information* structs_arr = (struct information*)malloc(sizeof(struct information)*(structs+1));
            for ( i = 0; i < structs; ++i ) {
               fread(&structs_arr[i], sizeof(struct information), 1, file);
            }
            fclose(file);
           memcpy(&structs_arr[structs], &info, sizeof(struct information));
           qsort(structs_arr, structs+1, sizeof(struct information), compar);
  
            for ( i = 0; i < structs+1; ++i ) {
               printf("user: %30s, iterations: %d\n", structs_arr[i].user, structs_arr[i].iterations);
            }
  
            file = fopen(filename, "wb");
           if ( !file ) {
              free(structs_arr);
              printf("can`t open file for writing");
              return 1;
          }
           for ( i = 0; i < structs+1; ++i ) {
              fwrite(&structs_arr[i], sizeof(struct information), 1, file);
           }
           free(structs_arr);
           fclose(file);
        }
        system("PAUSE");
      return 0;
   }
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
28.11.2010, 11:35
Ответы с готовыми решениями:

K&R параметры функции qsort
Ошибка компиляции на qsort. Что значит? Изменился стандарт, параметры у qsort явно больше. Как...

Отсортировать массив с помощью функции qsort
Приведите пожалуйста пример, как можно отсортировать массив с помощью функции qsort

Работа функции qsort - объяснить работу функции
#include&lt;iostream&gt; #include&lt;cstdlib&gt; int mysort(const void *arg1, const void *arg2); int main()...

Шаблон функции qsort()
Здорова! Нужно реализовать шаблон функции qsort(). Скачал пример и никак не могу разобраться как...

3
Эксперт С++
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
28.11.2010, 12:33 2
А что мешает использовать qsort для сортировки массива структур? Например, как здесь:
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
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
 
struct foo
{
    int     i;
    char    c[80];
};
 
struct foo* createf(struct foo* st, int i, const char* str)
{
    st->i = i;
    strcpy(st->c, str);
    return st;
}
 
int cmp(const void* a, const void* b)
{
    struct foo *pf1, *pf2;
    pf1 = (struct foo*) a;
    pf2 = (struct foo*) b;
    return (pf1->i < pf2->i ? -1 : (pf2->i < pf1->i ? 1 : strcmp(pf1->c, pf2->c)));
}
 
void displayf(struct foo* sts, size_t count)
{
    for(; count > 0; --count, ++sts)
        printf("i = %d, c = \'%s\'\n", sts->i, sts->c);
}
 
void fillf(struct foo* sts, size_t count)
{
    for(; count > 0; --count, ++sts)
    {
        printf("input i and c: ");
        scanf("%d %s", &(sts->i), sts->c);
    }
}
 
int main()
{
    const size_t size = 5;
    struct foo sts[size];
    fillf(sts, size);
    printf("\nstructs before sorting:\n");
    displayf(sts, size);
    qsort(sts, size, sizeof(*sts), cmp);
    printf("\nstructs after sorting:\n");
    displayf(sts, size);
    return 0;
}
0
0 / 0 / 2
Регистрация: 21.09.2010
Сообщений: 74
28.11.2010, 12:56  [ТС] 3
То, что qsort стандартная функция, а к этому могут придраться, что сортировка не расписана

Добавлено через 1 минуту
У меня сейчас больше стоит вопрос - как сделать, чтобы в статистике которая выводится на экран выводился ещё и введенный массив?
0
Эксперт С++
5828 / 3479 / 358
Регистрация: 08.02.2010
Сообщений: 7,448
28.11.2010, 12:59 4
Цитата Сообщение от vovalski Посмотреть сообщение
У меня сейчас больше стоит вопрос - как сделать, чтобы в статистике которая выводится на экран выводился ещё и введенный массив?
Ты не знаешь, как выводить массивы? В цикле выводишь по порядку каждый элемент массива. А насчет функции сортировки - в этом разделе есть прикрепленная тема, где этих сортировок полным-полно
0
28.11.2010, 12:59
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
28.11.2010, 12:59
Помогаю со студенческими работами здесь

Алгоритм работы функции qsort
Всем добрый день, у меня тут небольшая просьба. Кому не трудно, выложите пожалуйста простой...

исправление функции qsort сортировки матрицы
#include &quot;stdafx.h&quot; #include &lt;iostream&gt; #include &lt;math.h&gt; #include &lt;conio.h&gt; #include...

Шаблон функции сравнения для qsort()
Хочу отсортировать массив из int и из double с помощью qsort(). Для этого необходимо определить...

Выполнить сортировку массива с помощью стандартной функции быстрой сортировки qsort
Здравствуйте! прошу вас о помощи! помогите пожалуйста с программой! &quot;Выполнить сортировку массива...


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

Или воспользуйтесь поиском по форуму:
4
Ответ Создать тему
Новые блоги и статьи
Как проводить научные вычисления на Python
InfoMaster 15.01.2025
Python стал одним из наиболее востребованных языков программирования в области научных вычислений благодаря своей простоте, гибкости и обширной экосистеме специализированных библиотек. Научные. . .
Создание игры типа Minecraft на PyGame/Python: пошаговое руководство
InfoMaster 15.01.2025
В данном руководстве мы рассмотрим процесс создания игры в стиле Minecraft с использованием библиотеки PyGame на языке программирования Python. Этот проект идеально подходит как для начинающих. . .
Как создать свою первую игру в стиле Doom на Unreal Engine
InfoMaster 15.01.2025
Разработка шутера от первого лица в стиле классического Doom представляет собой увлекательное путешествие в мир игрового программирования, где сочетаются творческий подход и технические навыки. . . .
Параллельное программировани­е: основные технологии и принципы
InfoMaster 15.01.2025
Введение в параллельное программирование Параллельное программирование представляет собой фундаментальный подход к разработке программного обеспечения, который позволяет одновременно выполнять. . .
Как написать микросервис на C# с Kafka, MediatR, Redis и GitLab CI/CD
InfoMaster 15.01.2025
В современной разработке программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот подход позволяет разделить сложную систему. . .
Что такое CQRS и как это реализовать на C# с MediatR
InfoMaster 15.01.2025
Концепция CQRS и её роль в современной разработке В современном мире разработки программного обеспечения архитектурные паттерны играют ключевую роль в создании масштабируемых и поддерживаемых. . .
Как настроить CI/CD с Azure DevOps
InfoMaster 15.01.2025
CI/ CD, или непрерывная интеграция и непрерывное развертывание, представляет собой современный подход к разработке программного обеспечения, который позволяет автоматизировать и оптимизировать процесс. . .
Как настроить CI/CD с помощью Jenkins
InfoMaster 15.01.2025
Введение в CI/ CD и Jenkins В современной разработке программного обеспечения непрерывная интеграция (CI) и непрерывная доставка (CD) стали неотъемлемыми элементами процесса создания качественных. . .
Как написать микросервис на Go/Golang с Kafka, REST и GitHub CI/CD
InfoMaster 14.01.2025
Определение микросервиса, преимущества использования Go/ Golang Микросервис – это архитектурный подход к разработке программного обеспечения, при котором приложение состоит из небольших, независимо. . .
Как написать микросервис с нуля на C# с RabbitMQ, CQRS, Swagger и CI/CD
InfoMaster 14.01.2025
В современном мире разработки программного обеспечения микросервисная архитектура стала стандартом де-факто для создания масштабируемых и гибких приложений. Этот архитектурный подход предполагает. . .
Как создать интернет-магазин на PHP и JavaScript
InfoMaster 14.01.2025
В современном мире электронная коммерция стала неотъемлемой частью бизнеса. Создание собственного интернет-магазина открывает широкие возможности для предпринимателей, позволяя достичь большей. . .
Как написать Тетрис на Ассемблере
InfoMaster 14.01.2025
Тетрис – одна из самых узнаваемых и популярных компьютерных игр, созданная в 1984 году советским программистом Алексеем Пажитновым. За прошедшие десятилетия она завоевала симпатии миллионы людей по. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru