Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
 
Рейтинг 4.56/18: Рейтинг темы: голосов - 18, средняя оценка - 4.56
27 / 28 / 5
Регистрация: 17.10.2009
Сообщений: 739
1

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

10.04.2010, 18:41. Просмотров 3289. Ответов 10
Метки нет (Все метки)

Подскажите как можно сделать сортировку в файле по алфавиту.Если я записываю данные файл
например у меня наименование товара я ввожу через структуру и потом считываю через структуру из файла.Вот не могу понять как можно сделать легкую сортировку в файле где находяться наименования товаров.Подскажите пожалуйста
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
10.04.2010, 18:41
Ответы с готовыми решениями:

Cортировка строк в файле по возрастанию их длины
1)Дан текстовый файл, состоящий из некоторого количества строк. Написать функцию для сортировки...

Cортировка пузырьком
Программа не то, что не правильно работает, а просто даже не запускается, сразу же "прекращает...

Cортировка массива.
помогите с кодом, а то завтра надо уже сдать 1)При записи отсортированный массив у меня в файле...

Cортировка массива.
Доброго вечера. представлен массив ,не четные элементы данного массива нужно поместить в другой...

10
Эксперт С++
2329 / 1702 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 18:45 2
sergeu90,
1. Считываем содержащиеся в файле данные в массив структур.
2. Сортируем массив структур.
3. Записать отсортированный массив в файл, затерев исходные данные.
2
27 / 28 / 5
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 18:46  [ТС] 3
а код можешь не большой кинуть а то честно вообще не могу понять,то что ты написал вроде бы понял но так без кода не напишу
0
Эксперт С++
2329 / 1702 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 18:51 4
sergeu90, структуру, которою используешь покажи. И по какому полю сортировать надо.
0
27 / 28 / 5
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 18:54  [ТС] 5
C++
1
2
3
4
5
6
struct avto
{    
    char markaavtomobil[150];
    
};
 struct avto spravka;
вот
0
Эксперт С++
2329 / 1702 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 19:42 6
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
#include <iostream>
#include <fstream>
#include <vector>
#include <string>
#include <algorithm>
#include <exception>
 
struct Car {
  Car(const std::string& brand)
  : brand(brand) {
  }
 
  std::string brand;
};
 
bool operator < (const Car& left, const Car& right) {
  return left.brand < right.brand;
}
 
std::vector<Car> Load(const std::string& file_name) {
  std::ifstream file(file_name.c_str());
 
  if (!file)
    throw std::exception("Не удалось открыть файл для чтения");
 
  std::vector<Car> result;
 
  while (file) {
    std::string brand;
 
    std::getline(file, brand);
 
    result.push_back(Car(brand));
  }
 
  return result;
}
 
void Save(const std::string& file_name, const std::vector<Car> cars) {
  std::ofstream file(file_name.c_str(), std::ios_base::trunc);
 
  if (!file)
    throw std::exception("Не удалось открыть файл для перезаписи");
 
  for (std::vector<Car>::const_iterator it = cars.begin(); it != cars.end(); ++it)
    file << (*it).brand << std::endl;
}
 
int main() {
  setlocale(LC_ALL, "Russian");
 
  std::vector<Car> cars;
  const std::string file_name = "file_name.txt";
 
  try {
    cars = Load(file_name);
    std::sort(cars.begin(), cars.end());
    Save(file_name, cars);
  } catch (std::exception e) {
    std::cout << e.what() << std::endl;
  }
 
  return 0;
}
Про vector, string, exception, sort можешь прочитать здесь: http://www.cplusplus.com/.
2
1257 / 795 / 108
Регистрация: 16.09.2009
Сообщений: 2,010
10.04.2010, 19:54 7
Надо же C++ имеет офф сайт.
1
27 / 28 / 5
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 20:11  [ТС] 8
мне на чистом Си надо С++ не изучал(((((((
0
Эксперт С++
2329 / 1702 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 21:31 9
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);
1
27 / 28 / 5
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 21:33  [ТС] 10
а какие параметры в функцию compare передаються а то я что то не понимаю
0
Эксперт С++
2329 / 1702 / 148
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 21:42 11
sergeu90, функция сравнения Compare используется стандартной функцией qsort. qsort передает ей пары структур Car, Compare должна вернуть 1 если первый параметр больше* второго, 0 если они эквивалентны**, -1 если второй параметр больше* первого. Фактически благодаря функции Compare qsort определяет в каком порядке должны находится элементы массива структур Car (в каком направлении сортировать).

* Иначе можно прочитать как "должен находиться перед"
** Иначе можно прочитать как "стоят в правильном порядке"
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
10.04.2010, 21:42

Заказываю контрольные, курсовые, дипломные и любые другие студенческие работы здесь.

Cортировка массива
Здравствуйте! Существует задание: Дан массив n действительных чисел. Если исходный массив имеет...

Cортировка цифр
В данном натуральном числе переставить цифры таким образом, чтобы образовалось наименьшее число,...

Cортировка Шелла
надо перевести на метод шелла #include &lt;iostream&gt; #include &lt;cstdlib&gt; using namespace std;...

Cортировка матриц
Здраствуйте! Задание такое: отсортировать по возрастанию 1 рядок и 2 столбец матрицы. Так понимаю...


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

Или воспользуйтесь поиском по форуму:
11
Ответ Создать тему
Опции темы

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