0 / 0 / 0
Регистрация: 29.06.2015
Сообщений: 1
1

В заданной матрице поменять местами строку, содержащую максимальный элемент со строкой, содержащей минимальный

26.03.2016, 13:13. Показов 1914. Ответов 1

Надо сделать к понедельнику.
Задание по ПЯВУ, состоит из двух частей. Если первую часть я понимаю, как одномерный массив, то вторую нет. Преподаватель сказал, что 2-ая часть для двумерного массива.
Писала в wxDevC++
1) Написать программу построения массива с элементами:
a1, a1+a2, a1+a2+a3, a1+a2+a3+…+an
по данному массиву a1, a2,…, an.
2) В заданной матрице поменять местами две строки: строку, содержащую
максимальный элемент матрицы, и строку, содержащую минимальный элемент
матрицы.

Я писала ее так, но оказалось, что не правильно, потому что я просто переставляю строки.
Помогите!)
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
#include <cstdlib>
#include <iostream>
using namespace std;
int main(void)
{
int *a,*b, max, min, imax, imin;
int n;
   std::cout<<"n = "; std::cin>>n;
   a=new int [n];
   for (int i=0;i<n;i++)
      {
         std::cout<<"a["<<i+1<<"] = ";
         std::cin>>a[i];
      }
      b=new int [n];
   for (int i=0;i<n;i++)
      {
         b[i]=0;
         for (int l=i;l>=0;l--)
            b[i]+=a[l];
      }
   for (int i=0;i<n;i++)
      std::cout<<"b["<<i+1<<"] = "<<b[i]<<"\n";
  imax = 0;
  imin = 0;
  max = b[imax];
  min = b[imax];
   for (int i=1;i<n;i++)
      {
         if (b[i]>max) 
 { imax = i;
    max = b[i];
 }
         if (b[i]<min) 
 { imin = i;
    min = b[i];
 }
      }
b[imax] = min;
b[imin] = max; 
 
   for (int i=0;i<n;i++)
      std::cout<<"b["<<i+1<<"] = "<<b[i]<<"\n";
   delete [] b;
   system("pause");
   return 0;
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
26.03.2016, 13:13
Ответы с готовыми решениями:

В заданной матрице поменять строку, содержащую максимальный элемент со строкой, содержащей минимальный элемент
В данной действительной квадратной матрице размера m x n поменять строку, содержащую элемент с...

В заданной матрице поменять местами последнюю строку со строкой, содержащей минимальный элемент среди положительных
Помогите найти и исправить ошибку в программе, пожалуйста. В заданной матрице поменять местами...

В заданной матрице поменять местами первую строку со строкой, содержащей максимальный отрицательный элемент матрицы
Помогите, кто может! Нигде помощи не нашла, хотя подобные темы есть; не получается, а скоро...

Поменять местами строку, содержащую максимальный элемент массива, со строкой, содержащей минимальный элемент массива
сложно дались массивы, помогите написать код. Дан вещественный массив А. Поменять местами строку,...

1
16 / 16 / 13
Регистрация: 08.11.2014
Сообщений: 119
26.03.2016, 14:54 2
Второе задание, если я его правильно понял.
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
int main() {
    setlocale(LC_ALL, "rus");
    int len = 4;
    int** a = new int*[len]; int min = 1000, max = 0, imin, imax;
    int *buff = new int[len];
        
    for (int i = 0; i < len; i++)
    {
        a[i] = new int[len];
    }
 
    for (int i = 0; i < len; i++)
    {
        for (int j = 0; j < len; j++)
        {
            cin >> a[i][j];         
        }
    }
 
    for (int i = 0; i < len; i++)
    {
        for (int j = 0; j < len; j++)
        {
            if (min > a[i][j]) 
            {
                min = a[i][j];
                imin = i;
            }
            if (max < a[i][j])
            {
                max = a[i][j];
                imax = i;
            }
        }
    }
 
    for (int i = 0; i < 1; i++)
    {
        for (int j = 0; j < len; j++)
        {
            buff[j] = a[imax][j];
            a[imax][j] = a[imin][j];
            a[imin][j] = buff[j];
        }
    }
    
    for (int i = 0; i < len; i++)
    {
        for (int j = 0; j < len; j++)
        {
            cout << a[i][j]<< " ";
        }
        cout << endl;
    }
    cout << endl << "max = " << max << endl << "min = " << min;
    cout << endl << "imax = " << imax << endl << "imin = " << imin;
 
    system("pause");
    return 0;
}
1
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
26.03.2016, 14:54
Помогаю со студенческими работами здесь

В матрице поменять местами строку, содержащую наибольший элемент, со строкой, содержащей наименьший
Задание: В данной действительной матрице размера mn поменять местами строку, содержащую элемент...

В данной действительной матрице размера 3Х3 поменять местами строку, содержащую элемент с наибольшим значе-нием, со строкой, содержащей элемент с наим
В данной действительной матрице размера 3Х3 поменять местами строку, содержащую элемент с...

В матрице поменять местами строку, содержащую элемент с наибольшим значением, со строкой, содержащей элемент с наименьшим значением
В данной действительной матрице размера 3*3 поменять местами строку, содержащую элемент с...

Поменять местами строку, содержащую элемент с наибольшим значением, со строкой, содержащей элемент с наименьшим значение
Добрый день, помогите пожалуйста переделать программу #include &lt;iostream&gt; using namespace...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2023, CyberForum.ru