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

Странно работает сортировка - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Работа с датой и функция SetVolumeLabel http://www.cyberforum.ru/cpp-beginners/thread1151585.html
1) Изменение системной даты Делал так: void GetDate(time_t t,tm *tk) { time(&t); tk=localtime(&t); cout<<"Local date: "; if ((1+tk->tm_mon)<10) cout << tk->tm_mday<<".0" <<1+tk->tm_mon <<" " <<1900+tk->tm_year << endl;
C++ Копирование части строки, в новую строку Здравствуйте, помогите плиз с этой задачей. Заранее спасибо. Копирование в новую строку части исходной, начиная с элемента с заданным номером. http://www.cyberforum.ru/cpp-beginners/thread1151570.html
Проверить, есть ли пароль в массиве C++
Есть такой код: string z; string x = {"11111ab", "22222cd", "33333ef","44444gh","55555ij","66666kl"}; cin » z; if (z == x) { cout « "такой пароль есть в массиве"; }
C++ Как правильно создать функцию и затем вызвать ее
#include<string> #include <cmath> #include <iostream> #include<locale> using namespace std; int rl1,rl2,rl3,rl4,a,b,c,s; int main() { setlocale(LC_ALL,"Rus");
C++ Используя классы, создать упорядоченное бинарное дерево, которое описывает справочник файлов в файловой системе http://www.cyberforum.ru/cpp-beginners/thread1151550.html
Помогите пожалуйста с заданием. Используя классы, создать упорядоченное бинарное дерево, которое описывает справочник файлов в файловой системе. Каждому узлу соответствует некоторый фал , в узле содержится имя файла и дата последнего обращения к нему. Узлов в дереве не менее 35. Реализовать функцию, которая удаляет из дерева все файлы(узлы), в имени которых содержится расширение txt. и...
C++ Переписать программу с Паскаля на Си++ Привет всем. помогите переписать программу с Паскаля на Си++. Очень нужно. можно убрать графику и сделать все в консольке. Заранее спасибо)Program lab2; Uses Graph,CRT; Type rec1 = record X : integer; Y : integer; Tip: integer; end; rec2 = record Tip : integer; подробнее

Показать сообщение отдельно
SanekBW
0 / 0 / 0
Регистрация: 18.11.2013
Сообщений: 24
19.04.2014, 17:16     Странно работает сортировка
Всем привет! Только начинаю писать на c++, и не понятен один момент, необходимо по заданию В матрице 6*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
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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
// ipr_1.cpp: определяет точку входа для консольного приложения.
//
// В матрице 6*6 упорядочить элементы в каждой строке по убыванию, а строки матрицы расположить по возрастанию суммы элементов строк.
//
 
#include "stdafx.h"
#include <iostream>
#include <ctime> //Подключаем для функции time
#include <windows.h>
#include <locale>
using namespace std;
const int n=6;
 
int main()
{   
    setlocale(LC_ALL, ("Russian"));
    srand (time(NULL));
    cout<<"Первоначальный массив"<<endl<<endl;
    int **mass = new int* [n]; // Создаем массив указателей
    for (int i = 0; i < n; i++)
    {
        mass[i] = new int [n]; // Создаем элементы
    }
    for (int i=0; i<n; i++)
    {
        for (int j=0; j<n; j++)
        {
            mass[i][j]=rand() %100; // заполняем массив случайными числами от 0 до 99
            cout<<mass[i][j]<<" ";
        }
        cout << endl;
    }
    cout << endl;
    int temp; // сортировка значений в каждой строке по убыванию
    for(int i=0; i<n; i++)
    {
        for(int j=0;j<n-1;j++)
        {
            for (int k=j+1;k<n;k++)
            {
                if (mass[i][j] < mass[i][k])
                {
                    temp=mass[i][j];
                    mass[i][j]=mass[i][k];
                    mass[i][k]=temp;
                }
            }
        }
    }
    for (int i=0; i<n; i++) // Расчет суммы каждой строки
    {
        int sum=0;
        for (int j=0; j<n; j++)
        {
            sum = sum + mass[i][j];
        }
        mass[i][n]=sum;
    }
    cout<<"Суммы строк"<<endl<<endl; // Вывод сумм на экран
    for(int i=0; i<n; i++)
    {
        cout << mass[i][n] << endl;
    }
    cout<<endl;
    for (int i=0; i<n; i++) // Вывод массива отсортированного по убыванию значений в строке
    {
        for (int j=0; j<n; j++)
        {
            cout<<mass[i][j]<<" ";
        }
        cout << endl;
    }
    cout<<endl;
    for (int i=0;i<n-1;i++)// сортировка строк пор убыванию
    {
        for (int l=i+1; l<n; l++)
        {
            if (mass[i][n]>mass[l][n])
            {
                for (int j=0;j<n;j++)
                {
                    temp=mass[i][j];
                    mass[i][j]=mass[l][j];
                    mass[l][j]=temp;
                }
            }
        }
    }
    
    
    
    cout<<"Отсортированный массив"<<endl<<endl; // Вывод отсортированного массива на экран
    for (int i=0; i<n; i++)
    {
        for (int j=0; j<n; j++)
        {
            cout<<mass[i][j]<<" ";
        }
        cout << endl;
    }
    cout<<endl; 
    
    
    system("pause");
    // Удаление массива
    for (int i = 0; i < n; i++)
    {
        delete[]mass[i]; // Удаляем каждый элемент
    }
    delete [] mass; // А потом массив
    return 0;
}
Этот непонятный момент заключается в том, что последняя сортировка по возрастанию сумм строк, то работает, то нет, то работает криво(например загонит строку с минимальной суммой в конец или оставит ее по середине). Сидел долго, но так и не понял в чем проблема
Подскажите пожалуйста.

Добавлено через 1 час 12 минут
Спасибо, уже не надо, сам нашел
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 08:04. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru