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

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

Восстановить пароль Регистрация
 
Kings_ton
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 43
19.10.2013, 21:39     Воспользовавшись функцией сортировки массива, отсортировать строчки матрицы #1
Задача такая: воспользовавшись функцией сортировки массива, отсортировать строчки матрицы.
Я написал функцию для сортировки матрицы просто по возрастанию, она не получается.
Вот код:
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
#include <iostream>
#include <conio.h>
using namespace std;
int sortarr(int **matr,int n,int m)
{
    int stk;
for( int i=0; i < n-1; i++)
        for( int j=0; j < n-1-i; j ++)
            if (*(matr+j)> *(matr+j+1))
            {
                stk=**(matr+j);
                *(matr+j)= *(matr+j+1);
                **(matr+j+1)=stk;
            }
}
int main()
{
    int i,j,sum,stk;
    const int n =5, m=6;
    int matr[n][m];
   cout<<"Input matr\n";
    
    for(i=0; i<n; i++)
        for(j=0; j<m; j++)    
           cin>> *(*(matr+i)+j);
        sortarr(matr,n,m);
   cout<< "\nResult otsortirov mas\n";
    for( i=0; i<n; i++)
        cout<< *(matr+i)<<"  ";
    return 0;
}
Когда комплирую, выдает ошибку error C2664: 'sortarr' : cannot convert parameter 1 from 'int [5][6]' to 'int **'
Если можно напишите как реализовать задачу?
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.10.2013, 21:39     Воспользовавшись функцией сортировки массива, отсортировать строчки матрицы
Посмотрите здесь:

Возникли трудности с функцией быстрой сортировки qsort C++
C++ Динамический массив отсортировать по возростанию методом быстрой сортировки
Отсортировать масив методом пузырьковой сортировки C++
Воспользовавшись указателями, поменяйте местами элементы массива с четными и нечетными индексами C++
Заданы матрицы А, В, С, D, каждая из которых содержит по три строчки и по три столбца. Перемножить матрицы Р и Q C++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4925 / 2668 / 243
Регистрация: 29.11.2010
Сообщений: 7,421
20.10.2013, 03:23     Воспользовавшись функцией сортировки массива, отсортировать строчки матрицы #2
Цитата Сообщение от Kings_ton Посмотреть сообщение
Когда комплирую, выдает ошибку error C2664: 'sortarr' : cannot convert parameter 1 from 'int [5][6]' to 'int **'
Если хотите передавать в функцию двумерный массив, выделяйте память динамически. И не забудьте её освободить

Добавлено через 31 секунду
Цитата Сообщение от Kings_ton Посмотреть сообщение
if (*(matr+j)> *(matr+j+1))
* * * * * * {
* * * * * * * * stk=**(matr+j);
* * * * * * * * *(matr+j)= *(matr+j+1);
* * * * * * * * **(matr+j+1)=stk;
* * * * * * }
оставьте эту ересь для старперов, есть же operator[]
Kings_ton
0 / 0 / 0
Регистрация: 19.10.2013
Сообщений: 43
20.10.2013, 16:28  [ТС]     Воспользовавшись функцией сортировки массива, отсортировать строчки матрицы #3
Что такое operator[]?

Добавлено через 10 минут
написал вот так, все равн не работает:
#include <iostream>
#include <conio.h>
using namespace std;
void sortarr(int **matr,int n,int m)
{
int stk;
for( int i=0; i < n-1; i++)
for( int j=0; j < n-1-i; j ++)
if (*(matr+j)> *(matr+j+1))
{
stk=**(matr+j);
*(matr+j)= *(matr+j+1);
**(matr+j+1)=stk;
}
}
int main()
{
setlocale(LC_CTYPE,"rus");
int n,m;
cout<<"Введите количество строк и столбцов:";
cin>>n>>m;
//if(n<=o || m<=0,return 1)
int **matr=new int* [n];
for(int i=0;i<n;i++)
matr[i]=new int [m];
for(int i=0;i<n;i++,cout<<'\n')
for(int j=0;j<m;j++)
{
matr [i][j]=rand()%20-10;
cout<<matr[i][j]<<'\t';
}

cout<< "\nResult otsortirov mas\n";
sortarr(matr,n,m);
for(int i=0;i<n;i++)
delete[]matr[i];
delete[]matr;
return 0;
return 0;
}
MrGluck
Ворчун
Эксперт С++
 Аватар для MrGluck
4925 / 2668 / 243
Регистрация: 29.11.2010
Сообщений: 7,421
21.10.2013, 00:18     Воспользовавшись функцией сортировки массива, отсортировать строчки матрицы #4
Цитата Сообщение от Kings_ton Посмотреть сообщение
Что такое operator[]?
оператор обращения по индексу, например для массива a будет a[2]
Yandex
Объявления
21.10.2013, 00:18     Воспользовавшись функцией сортировки массива, отсортировать строчки матрицы
Ответ Создать тему
Опции темы

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