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

Cортировка в файле - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ написать программу перезагрузки функции поиска минимального элемента в массиве. элементы массива могут быть вещественные и целые. http://www.cyberforum.ru/cpp-beginners/thread115053.html
написать программу перезагрузки функции поиска минимального элемента в массиве. элементы массива могут быть вещественные и целые. напишите плиз....
C++ error C2664: платформа Visual C++ 2008 Всем доброго времени суток! Изучаю сейчас Visual Studio 2008. Компилятор выдает вот такую ошибку: error C2440: приведение типов: невозможно преобразовать 'wmain::Blocknotes' в 'char *' 1> Для выполнения данного преобразования нет доступного оператора преобразования, определенного пользователем, или вызов оператора невозможен Вот в этой строке: FILE.write((char*)b,sizeof(b)); ... http://www.cyberforum.ru/cpp-beginners/thread115034.html
C++ Найти среднее арифметическое значение элементов массива
#include <iostream> using namespace std; int shet(int *m, int n) { int x,sum=0; cout<<"vvedite elementi:"<<endl; for(int i=0;i<n;i++) cin>>m;
Сохранить список C++
Привет всем! Может напишу не очень понятно, но.. Чочу создать контейнер(или класс), назовем его My_list, на основе списка (list<typename>...) кот. содержит набор объектов типа typename. Из этих обектов я хитрым образом c помощью функции getObj() выбираю один. Класс я написал Собственно проблема: не могу понять как можно создать объект класса My_list object один раз с определенным...
C++ Как можно представить дерево http://www.cyberforum.ru/cpp-beginners/thread115008.html
Как можно представить дерево в с.с++?
C++ Битовый массив (значения принимаются битами, а адресация по номеру бита) Реализовать только на языке C. Битовый массив (значения принимаются битами, а адресация по номеру бита.) подробнее

Показать сообщение отдельно
CyBOSSeR
Эксперт C++
 Аватар для CyBOSSeR
2293 / 1663 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 21:31     Cортировка в файле
sergeu90, проверяй:
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 <stdio.h>
#include <stdlib.h>
 
#define MAX_LENGHT 255
 
enum FileResult {
  frOK,
  frOpenError,
  frReadError,
  frWriteError,
};
 
struct Car {
  char brand[MAX_LENGHT];
};
 
enum FileResult Load(char* file_name, struct Car** p_arr, int* p_size) {
         FILE* file;
  struct Car*  arr;
         int   size;
         int   i;
 
  if ((file = fopen(file_name, "r")) == NULL)
    return frOpenError;
 
  if (fscanf(file, "%d", &size) != 1)
    return frReadError;
 
  arr = (struct Car*)malloc(size * sizeof(struct Car));
 
  for (i = 0; i < size; ++i)
    if (fscanf(file, "%s", arr[i].brand) != 1)
      return frReadError;
 
  *p_arr  = arr;
  *p_size = size;
 
  return frOK;
}
 
enum FileResult Save(char* file_name, struct Car* arr, int size) {
  FILE* file;
  int   i;
 
  if ((file = fopen(file_name, "w")) == NULL)
    return frOpenError;
 
  if (fprintf(file, "%d\n", size) != 1)
      return frWriteError;
  
  for (i = 0; i < size; ++i)
    if (fprintf(file, "%s\n", arr[i].brand) != 1)
      return frWriteError;
 
  return frOK;
}
 
int Compare(void* left, void* right) {
  return strcmp(((struct Car*)left)->brand, ((struct Car*)right)->brand);
}
 
void Sort(struct Car* arr, int size) {
  qsort((void*)arr, size, size * sizeof(struct Car), Compare);
}
 
int main() {
  struct Car* arr                   = NULL;
         int  size                  = 0;
         char file_name[MAX_LENGHT] = "file_name.txt";
 
  if (Load(file_name, &arr, &size) != frOK)
    return EXIT_FAILURE;
 
  Sort(arr, size);
 
  if (Save(file_name, arr, size) != frOK)
    return EXIT_FAILURE;
 
  return EXIT_SUCCESS;
}
Поправка: вместо строки
C
1
qsort((void*)arr, size, size * sizeof(struct Car), Compare);
поставь
C
1
qsort((void*)arr, size, sizeof(struct Car), Compare);
 
Текущее время: 12:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru