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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
#1

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

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

Подскажите как можно сделать сортировку в файле по алфавиту.Если я записываю данные файл
например у меня наименование товара я ввожу через структуру и потом считываю через структуру из файла.Вот не могу понять как можно сделать легкую сортировку в файле где находяться наименования товаров.Подскажите пожалуйста
0
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
10.04.2010, 18:41
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Cортировка в файле (C++):

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

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

Cортировка Шелла - C++
надо перевести на метод шелла #include <iostream> #include <cstdlib> using namespace std; int main() { ...

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

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

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

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
CyBOSSeR
Эксперт C++
2303 / 1673 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 18:45 #2
sergeu90,
1. Считываем содержащиеся в файле данные в массив структур.
2. Сортируем массив структур.
3. Записать отсортированный массив в файл, затерев исходные данные.
2
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 18:46  [ТС] #3
а код можешь не большой кинуть а то честно вообще не могу понять,то что ты написал вроде бы понял но так без кода не напишу
0
CyBOSSeR
Эксперт C++
2303 / 1673 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 18:51 #4
sergeu90, структуру, которою используешь покажи. И по какому полю сортировать надо.
0
sergeu90
27 / 28 / 3
Регистрация: 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
CyBOSSeR
Эксперт C++
2303 / 1673 / 86
Регистрация: 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
Genius Ignat
1236 / 774 / 44
Регистрация: 16.09.2009
Сообщений: 2,014
10.04.2010, 19:54 #7
Надо же C++ имеет офф сайт.
1
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 20:11  [ТС] #8
мне на чистом Си надо С++ не изучал(((((((
0
CyBOSSeR
Эксперт C++
2303 / 1673 / 86
Регистрация: 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
sergeu90
27 / 28 / 3
Регистрация: 17.10.2009
Сообщений: 739
10.04.2010, 21:33  [ТС] #10
а какие параметры в функцию compare передаються а то я что то не понимаю
0
CyBOSSeR
Эксперт C++
2303 / 1673 / 86
Регистрация: 06.03.2009
Сообщений: 3,675
10.04.2010, 21:42 #11
sergeu90, функция сравнения Compare используется стандартной функцией qsort. qsort передает ей пары структур Car, Compare должна вернуть 1 если первый параметр больше* второго, 0 если они эквивалентны**, -1 если второй параметр больше* первого. Фактически благодаря функции Compare qsort определяет в каком порядке должны находится элементы массива структур Car (в каком направлении сортировать).

* Иначе можно прочитать как "должен находиться перед"
** Иначе можно прочитать как "стоят в правильном порядке"
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
10.04.2010, 21:42
Привет! Вот еще темы с ответами:

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

Cортировка двусвязного списка - C++
Ну, в общем задание в названии. Нужно отсортировать двусвязный список, методом пузырька. Сортировку-то я эту знаю. Но вот проблема, я не...

Cортировка динамической матрицы - C++
Отсортировать каждую строку динамической матрицы по возрастанию и вывести новую матрицу с упорядоченными строками Помогите...не...

Cортировка методом Шелла - C++
Нужно выполнить сортировку 5-видов, 4 нормально работают, а 5 (методом Шелла) не работает. Которые работают, они закоменчены) помогите...


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

Или воспользуйтесь поиском по форуму:
Yandex
Объявления
10.04.2010, 21:42
Ответ Создать тему
Опции темы

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