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

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

Войти
Регистрация
Восстановить пароль
 
sssasha
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 23
#1

Как сделать чтобы потом выводило матрицу с максимумом и минимумом, которые я нашел, поменяными местами? - C++

26.11.2014, 00:18. Просмотров 241. Ответов 9
Метки нет (Все метки)

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
//
#include <iostream>
#include<iomanip>
#include<cstdlib>
using namespace std;
 
 
int main()
{
    const size_t size(3);
    int **matrix = new int* [size];
    for(size_t i=0; i<size; ++i)
        matrix[i] = new int [size];
    for(size_t i=0; i<size; ++i)
    {
        for(size_t j=0; j<size; ++j)
            std::cout<<std::setw(2)<<(matrix[i][j] = rand()%10);
        std::cout<<"\n";
    }
    int maximal(matrix[0][0]),minimal(matrix[0][0]);
    for(size_t i=0; i<size; ++i)
        for(size_t j=0; j<size; ++j)
        {
            if((i > j) && matrix[i][j] < minimal)
                minimal = matrix[i][j];
            if((i > j) && matrix[i][j] > maximal)
                maximal = matrix[i][j];
   }
    std::cout<<"\nmin: "<<minimal<<"\nmax: "<<maximal;
}
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
26.11.2014, 00:18
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Как сделать чтобы потом выводило матрицу с максимумом и минимумом, которые я нашел, поменяными местами? (C++):

Как сделать чтобы ответ выводило таблицей по 10 чисел? - C++
Как сделать чтобы ответ выводило таблицей по 10 чисел? Ниже написан код программы #include &lt;iostream&gt; #include &lt;conio.h&gt; // для...

как сделать чтобы читало русские буквы с массива и выводило русский шрифт при функции рекурсии - C++
Добрый день #include &lt;iostream&gt; using namespace std; void reverse(char *s); int main()

Количество элементов между минимумом и максимумом - C++
Пожалуйста помогите вот с этой задачей!!! Написать программу, которая для целочисленной матрицы 10х20 определяет среднее...

Найти сумму между максимумом и минимумом в массиве. - C++
Найти сумму между максимумом и минимумом в массиве. Подскажите пожалуйста, почему выдает не правильный ответ? Как исправить???? Пишу...

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

Найти сумму элементов массива между максимумом и минимумом - C++
Дан одномерный массив. Найти сумму элементов между максимумом и минимумом

Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Zver6233
36 / 36 / 8
Регистрация: 21.06.2013
Сообщений: 271
Записей в блоге: 1
26.11.2014, 00:53 #2
Цитата Сообщение от sssasha Посмотреть сообщение
#include <iostream>
#include<iomanip>
#include<cstdlib>
using namespace std;
int main()
{
const size_t size(3);
int **matrix = new int* [size];
for(size_t i=0; i<size; ++i)
matrix[i] = new int [size];
for(size_t i=0; i<size; ++i)
{
for(size_t j=0; j<size; ++j)
std::cout<<std::setw(2)<<(matrix[i][j] = rand()%10);
std::cout<<"\n";
}
int maximal(matrix[0][0]),minimal(matrix[0][0]);
for(size_t i=0; i<size; ++i)
for(size_t j=0; j<size; ++j)
{
if((i > j) && matrix[i][j] < minimal)
minimal = matrix[i][j];
if((i > j) && matrix[i][j] > maximal)
maximal = matrix[i][j];
}
std::cout<<"\nmin: "<<minimal<<"\nmax: "<<maximal;
}
найди индекса минимального и максимального. потом с помощью дополнительной переменной переставь местами мин и макс. будет это виглядить примерно так :

C++
1
2
3
temp=matrix[mini][minj];
        matrix[mini][minj]=matrix[maxi][maxj];
        matrix[maxi][maxj]=temp;
где mini,minj,maxi,maxj это индекса
sssasha
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 23
26.11.2014, 01:01  [ТС] #3
Спасибо)
А как потом вывести измененную матрицу?
И как это вообще оформить?
Zver6233
36 / 36 / 8
Регистрация: 21.06.2013
Сообщений: 271
Записей в блоге: 1
26.11.2014, 01:03 #4
for(i=0....){
for(j=0....)
cout<<matrix[i][j];
cout<<endl;
}
sssasha
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 23
26.11.2014, 01:08  [ТС] #5
Спасибо)))

Добавлено через 4 минуты
А как индекс найти?)
Zver6233
36 / 36 / 8
Регистрация: 21.06.2013
Сообщений: 271
Записей в блоге: 1
26.11.2014, 01:28 #6
Цитата Сообщение от sssasha Посмотреть сообщение
Спасибо)))
Добавлено через 4 минуты
А как индекс найти?)
C++
1
2
3
4
5
6
7
8
9
10
  if((i > j) && matrix[i][j] < minimal)
                        {
                        mini=i;minj=j;
                        minimal = matrix[i][j];
                        }
                if((i > j) && matrix[i][j] > maximal)
                        {
                        maxi=i;maxj=j;
                        maximal = matrix[i][j];
                        }
sssasha
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 23
26.11.2014, 01:34  [ТС] #7
Где ошибки? Можешь исправить пожалуйста)))

Добавлено через 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
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
//
#include <iostream>
#include<iomanip>
#include<cstdlib>
using namespace std;
 
 
int main()
{
    const size_t size(4);
    int **matrix = new int* [size];
    for(size_t i=0; i<size; ++i)
        matrix[i] = new int [size];
    for(size_t i=0; i<size; ++i)
    {
        for(size_t j=0; j<size; ++j)
            std::cout<<std::setw(1)<<(matrix[i][j] = rand()%10);
        std::cout<<"\n";
    }
    std::cout<<"\n";
    int maximal(matrix[0][0]),minimal(matrix[0][0]);
    int maxi=0,maxj=0, mini=0, minj=0; 
    int temp=matrix[0][0];
    for(size_t i=0; i<size; ++i)
        for(size_t j=0; j<size; ++j)
        {
           if((i > j) && matrix[i][j] < minimal)
                        {
                        mini=i;minj=j;
                        minimal = matrix[i][j];
                        }
                if((i > j) && matrix[i][j] > maximal)
                        {
                        maxi=i;maxj=j;
                        maximal = matrix[i][j];
                        }
  {
    temp=matrix[mini][minj];
        matrix[mini][minj]=matrix[maxi][maxj];
        matrix[maxi][maxj]=temp;
 
  }
   }
 
    for(size_t i=0; i<size; ++i){
for(size_t j=0; j<size; ++j)
cout<<matrix[i][j];
cout<<endl;
}
}
Zver6233
36 / 36 / 8
Регистрация: 21.06.2013
Сообщений: 271
Записей в блоге: 1
26.11.2014, 01:45 #8
Цитата Сообщение от sssasha Посмотреть сообщение
const size_t size(4);
int **matrix = new int* [size];
for(size_t i=0; i<size; ++i)
matrix[i] = new int [size];
for(size_t i=0; i<size; ++i)
{
for(size_t j=0; j<size; ++j)
std::cout<<std::setw(1)<<(matrix[i][j] = rand()%10);
std::cout<<"\n";
}
std::cout<<"\n";
int maximal(matrix[0][0]),minimal(matrix[0][0]);
int maxi=0,maxj=0, mini=0, minj=0;
int temp=matrix[0][0];
for(size_t i=0; i<size; ++i)
for(size_t j=0; j<size; ++j)
{
if((i > j) && matrix[i][j] < minimal)
{
mini=i;minj=j;
minimal = matrix[i][j];
}
if((i > j) && matrix[i][j] > maximal)
{
maxi=i;maxj=j;
maximal = matrix[i][j];
}
{
temp=matrix[mini][minj];
matrix[mini][minj]=matrix[maxi][maxj];
matrix[maxi][maxj]=temp;
}
}
for(size_t i=0; i<size; ++i){
for(size_t j=0; j<size; ++j)
cout<<matrix[i][j];
cout<<endl;
}
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
#include <iostream>
#include <vcl>
#include <conio>
using namespace std;
int main()
{
int i,j;
const size_t size(4);
int **matrix = new int* [size];
for(size_t i=0; i<size; ++i)
        matrix[i] = new int [size];
for(size_t i=0; i<size; ++i)
{
        for(size_t j=0; j<size; ++j)
        cout<<(matrix[i][j] = rand()%10);
        cout<<"\n";
}
        cout<<"\n";
        int maximal(matrix[0][0]),minimal(matrix[0][0]);
        int maxi=0,maxj=0, mini=0, minj=0;
        int temp;
        for(size_t i=0; i<size; ++i)
        {
        for(size_t j=0; j<size; ++j)
        {
        if((i > j) && matrix[i][j] < minimal)
        {
        mini=i;minj=j;
        minimal = matrix[i][j];
        }
        if((i > j) && matrix[i][j] > maximal)
        {
        maxi=i;maxj=j;
        maximal = matrix[i][j];
        }
        }
        }
        temp=matrix[mini][minj];
        matrix[mini][minj]=matrix[maxi][maxj];
        matrix[maxi][maxj]=temp;
 
cout<<"min"<<minimal<<"max"<<maximal<<endl;
 
 
 
for(size_t i=0; i<size; ++i)
{
for(size_t j=0; j<size; ++j)
cout<<matrix[i][j]<<" ";
cout<<endl;
}
 
 
getch();
return 0;
}
sssasha
0 / 0 / 0
Регистрация: 25.11.2014
Сообщений: 23
02.12.2014, 22:55  [ТС] #9
а как переписать эту же прогу но через функцию? помогите пожалуйста)
Zver6233
36 / 36 / 8
Регистрация: 21.06.2013
Сообщений: 271
Записей в блоге: 1
02.12.2014, 23:47 #10
Цитата Сообщение от sssasha Посмотреть сообщение
а как переписать эту же прогу но через функцию? помогите пожалуйста)
то есть? мин и максимум искало через функцию? или переставляло местами?
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
02.12.2014, 23:47
Привет! Вот еще темы с ответами:

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

Найти разницу между максимумом и минимумом в каждой строке массива - C++
Дана действительная матрица размером n*m. Определить числа {b}_{0}, ... , {b}_{n-1}, равные соответственно разностям наибольших и...

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

помогите сделать цикл,чтобы выводило ряд Фибоначии до определенного числа N которое я ввела с клавиатуры. - C++
есть у меня код рекурсии по нахождению числа фибоначчи за номером. помогите сделать цикл,чтобы выводило ряд Фибоначии до определенного...


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

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

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