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

Файловая сортировка (не обычно) - C++

Восстановить пароль Регистрация
 
borovik
208 / 202 / 1
Регистрация: 25.07.2010
Сообщений: 1,131
19.10.2010, 17:16     Файловая сортировка (не обычно) #1
привет всем, нужно отсортировать по возрастанию данную конструкцию.
В файле так:
23 54 87
95 37 24
48 30 27
89 27 12
C++
1
2
3
4
5
6
ifstream f;
int a,b,c;
f.open("1.txt");
while(!f.eof()){
f>>a>>b>>c;
}
Подскажите как отсортировать строки по второму столбцу (по убыванию).
Пробовал хитреные системы с двухмерными массивами но на столько усложнил что ужас....
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
LineStown
 Аватар для LineStown
63 / 63 / 3
Регистрация: 04.08.2010
Сообщений: 399
19.10.2010, 17:28     Файловая сортировка (не обычно) #2
Отсортировать 2-й столбец, как одномерный масив (использовать 2-х мерный масив, как никрути), только в момент замены мест элементов переносить не только элемент 2-го столбца, а всю строку
borovik
208 / 202 / 1
Регистрация: 25.07.2010
Сообщений: 1,131
19.10.2010, 17:33  [ТС]     Файловая сортировка (не обычно) #3
как это реализовать?
по 6 переменных или как то ещё я представляю это так
C++
1
2
3
4
5
6
7
8
9
int a,b,c;
int z,x,v;
f>>a>>b>>c;
while(!f.eof()){
f>>z>>x>>v;
if (b<x){
 //дальше хз как
}
}
LineStown
 Аватар для LineStown
63 / 63 / 3
Регистрация: 04.08.2010
Сообщений: 399
19.10.2010, 17:36     Файловая сортировка (не обычно) #4
C++
1
2
3
4
5
6
7
int mas[3][3];
int x=0;
while(!f.eof())
{
f>>mas[x][0]>>mas[x][1]>>mas[x][2];
x++;
}
Считывать при известной размерности матрицы
fasked
Эксперт C++
 Аватар для fasked
4924 / 2504 / 180
Регистрация: 07.10.2009
Сообщений: 4,306
Записей в блоге: 1
19.10.2010, 17:55     Файловая сортировка (не обычно) #5
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
#include <stdio.h>
#include <stdlib.h>
 
#define SIZE    3
#define SORTED  1
 
void swap_rows(int *a, int *b, int len) {
    int i, temp;
    for(i = 0; i < len; ++i) {
        temp = a[i];
        a[i] = b[i];
        b[i] = temp;
    }
}
 
int main()
{
    int i = 0;
    int j = 0;
    int data[SIZE][SIZE];
 
    // пусть для примера массив заполнен случайным образом
    for(i = 0; i < SIZE; ++i) {
        for(j = 0; j < SIZE; ++j)
            data[i][j] = rand() % 99;
    }
 
    for(i = 0; i < SIZE; ++i) {
        for(j = 0; j < SIZE; ++j)
            printf("%02d ", data[i][j]);
        printf("\n");
    }
 
    for(i = 0; i < SIZE; ++i) {
        for(j = SIZE - 1; j > i; --j) {
            if(data[j][SORTED] > data[j-1][SORTED]) {
                swap_rows(data[j], data[j-1], SIZE);
            }
        }
    }
 
    printf("after sort: \n");
    for(i = 0; i < SIZE; ++i) {
        for(j = 0; j < SIZE; ++j)
            printf("%02d ", data[i][j]);
        printf("\n");
    }
}
Yandex
Объявления
19.10.2010, 17:55     Файловая сортировка (не обычно)
Ответ Создать тему
Опции темы

Текущее время: 23:46. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru