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

Процедуры на С++ - C++

Восстановить пароль Регистрация
 
Рейтинг: Рейтинг темы: голосов - 12, средняя оценка - 4.75
Марик73
0 / 0 / 0
Регистрация: 19.12.2010
Сообщений: 42
01.12.2011, 20:25     Процедуры на С++ #1
Помогите пожалуйста с такой задачей:

Составить процедуру упорядочения одномерного массива по убыванию. С помощью процедуры отсортировать столбцы произвольно заданной двумерной матрицы. При этом вновь полученные строки также должны быть отсортированы по убыванию.
Заранее большое спасибо.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
01.12.2011, 20:25     Процедуры на С++
Посмотрите здесь:

C++ Процедуры. Процедуры-функции
Процедуры на С... C++
Процедуры и функции C++
C++ процедуры в qt
C++ процедуры в с++
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
ZaVyLoN
 Аватар для ZaVyLoN
83 / 83 / 6
Регистрация: 26.10.2009
Сообщений: 269
01.12.2011, 20:50     Процедуры на С++ #2
При этом вновь полученные строки также должны быть отсортированы по убыванию.
Имеется ввиду потом уже строки отсортировать?
т.к. матрица произвольная неможит быть одновременно отсортирована по столб. и строкам.
Марик73
0 / 0 / 0
Регистрация: 19.12.2010
Сообщений: 42
01.12.2011, 21:14  [ТС]     Процедуры на С++ #3
Цитата Сообщение от ZaVyLoN Посмотреть сообщение
Имеется ввиду потом уже строки отсортировать?
т.к. матрица произвольная неможит быть одновременно отсортирована по столб. и строкам.
Да. Сначала сортируется по столбцам, а после по строкам.
PointsEqual
ниначмуроФ
 Аватар для PointsEqual
832 / 516 / 33
Регистрация: 12.10.2009
Сообщений: 1,915
01.12.2011, 21:16     Процедуры на С++ #4
ну вот так можно отсортировать строки

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
#include <iostream>
#include <vector>
#include <algorithm>
 
using namespace std;
 
 
const int SIZE = 5;
 
 
int main()
{
 
    vector<int> tmp = {2,9,5,1,6};
    vector<vector<int>> m;
 
    for(int i = 0; i < SIZE; ++i)
    {
        m.push_back(tmp);
    }
 
    for(vector<vector<int>>::iterator i = m.begin(); i != m.end(); ++i)
    {
        sort(i->begin(), i->end(), greater<int>());
    }
 
    return 0;
}
а столбцы... надо делать...
ZaVyLoN
 Аватар для ZaVyLoN
83 / 83 / 6
Регистрация: 26.10.2009
Сообщений: 269
01.12.2011, 21:21     Процедуры на С++ #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
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 <stdlib.h>
#include <stdio.h>
 
#define N 3
 
void func(int **massive);
int* sort(int *mas);
 
int main()
{
    int **arr = (int**) malloc (N * sizeof(int));
    for (int i = 0; i < N; i++) 
        *(arr + i) = (int*) malloc (N * sizeof(int));
 
        
   
    printf("Enter the matrix\n");
    for(int i = 0; i < N; i++)
    {
        for(int j = 0; j < N; j++)
        {
            scanf("%d", &(*(*(arr + i) + j)));
        }
    }
 
    func(arr);
        
    printf("Show matrix\n");
    for(int i = 0; i < N; i++)
    {
        for(int j = 0; j < N; j++)
        {
            printf("%d ", *(*(arr + i) + j));
        }
        printf("\n");   
    }
        
    for(int i = 0; i < N; i++)
        free(arr[i]);
    free(arr);
 
    return 0;
}
 
 
void func(int **massive)
{
    for(int i = 0; i < N; i++)
    {
        int *temp = (int*) malloc (N * sizeof(int));
                                
        for(int k = 0; k < N; k++)
            *(temp+k) = *(*(massive + k) + i);
 
        sort (temp);
 
        for(int k = 0; k < N; k++)
            *(*(massive + k) + i) = *(temp+k);
    }
        
}
 
 
int *sort(int *mas)
{
    int temp;
    for(int i = 0; i < N; i++)
    {
        for(int j = 0; j < N - i - 1; j++)
        {
            if(*(mas + j) < *(mas + j + 1))
            {
                temp = *(mas + j);
                *(mas + j) = *(mas + j + 1);
                *(mas + j + 1) = temp;
            }
        }
    }
    return mas;
}
Добавлено через 53 секунды
Черт, на с++ же
go
Эксперт C++
3582 / 1362 / 128
Регистрация: 16.04.2009
Сообщений: 4,528
01.12.2011, 21:42     Процедуры на С++ #6
Цитата Сообщение от Марик73 Посмотреть сообщение
процедуру
В C++ не существует процедур, есть функция, которая ничего не возвращает
C++
1
2
3
4
void fun ()
{
 
}
Марик73
0 / 0 / 0
Регистрация: 19.12.2010
Сообщений: 42
05.12.2011, 10:56  [ТС]     Процедуры на С++ #7
[QUOTE=ZaVyLoN;2236409]Составить процедуру упорядочения одномерного массива по убыванию. С помощью процедуры отсортировать столбцы произвольно заданной двумерной матрицы.

Вот код на эту часть задания.

[C]#include <stdlib.h>
#include <stdio.h>

#define N 3
...

Выдаются ошибки:

Multiple declaration for 'i'
Multiple declaration for 'k'
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
05.12.2011, 15:56     Процедуры на С++
Еще ссылки по теме:

C++ процедуры и функции
Процедуры C++
C++ Подпрограммы-процедуры и процедуры-функции

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

Или воспользуйтесь поиском по форуму:
ZaVyLoN
 Аватар для ZaVyLoN
83 / 83 / 6
Регистрация: 26.10.2009
Сообщений: 269
05.12.2011, 15:56     Процедуры на С++ #8
Объявите i, k перед циклами.
и в циклах уберите инициализацию этих переменных
Yandex
Объявления
05.12.2011, 15:56     Процедуры на С++
Ответ Создать тему
Опции темы

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