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

Убрать строку массива с минимальным элементом главной строки

16.03.2018, 16:00. Показов 1102. Ответов 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
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
#include <iostream>
#include <iomanip>
#include <stdlib.h> 
#include <ctime> 
 
using namespace std;
 
int main()
{
    srand(time(NULL));  
    int n = 0;
    cout << "Size matrix :  " ;
    cin >> n; 
    int **a = new int* [n]; 
    for (int i = 0; i < n; i++)
    {
        a[i] = new int [n]; 
    } 
    
    for (int i = 0; i < n; i++)
    {
        for (int j = 0; j < n; j++)
        {
            a[i][j] = rand() % 10; 
            cout << a[i][j] << " "; 
        }
        cout << endl; 
    }
    
        int min = a[0][0];
        
        for(int i=0 ; i < n; ++i)
        {
            
            if( a[i][i] < min)
            min = a[i][i];
            
        }
          cout << min << endl;
          
    
  int i,j;
    
for (i=0;i<n;i++)
    {
        for (j=0;j<n;j++)
            if (i==min)
 
                cout<<" "<<a[i][j];
        cout<<endl;
    }
    for (i=0;i<n;i++)
        delete[] a[i];
    delete[] a;
    
        
            
        
    return 0;
}
Не могу понять как убрать правильно,еще и в новой матрице.
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
16.03.2018, 16:00
Ответы с готовыми решениями:

В заданной матрице заменить строки с максимальным элементом на строку с минимальным элементом
Помогите девочке очень срочно нужна помощь Замена в матрице строки с максимальны элементом на...

В массиве необходимо найти номер строки с минимальным элементом. Поменять местами строку с минимальным элементом и пе
2. В массиве необходимо найти номер строки с минимальным элементом. Поменять местами строку с...

Переставить строку с минимальным элементом на главной диагонали матрицы со строкой с заданным номером
Помогите пожалуйста с задачкой Дан массив R(m,m).Надо переставить строку с минимальным элементом...

Поменять местами строку с минимальным элементом на главной диагонали со строкой с заданным номером t.
Задана квадратная матрица, размерности n, где n=2z. Поменять местами строку с минимальным...

9
7533 / 6396 / 2916
Регистрация: 14.04.2014
Сообщений: 27,859
16.03.2018, 18:39 2
Создаёшь матрицу с меньшим количеством строк и копируешь в неё все строки кроме той, где минимум.
0
1754 / 1346 / 1407
Регистрация: 28.10.2016
Сообщений: 4,267
16.03.2018, 18:40 3
nmcf, ну тут условие такое, что таких строк может быть несколько.
Намного проще будет сделать с векторами и физическим удалением строк
0
0 / 0 / 0
Регистрация: 06.01.2018
Сообщений: 28
16.03.2018, 18:42  [ТС] 4
А как мне написать кодом,что б прога знала какие строки копировать?Ведь строкой с минимальным может оказаться любая...
0
1754 / 1346 / 1407
Регистрация: 28.10.2016
Сообщений: 4,267
16.03.2018, 18:44 5
AnAlCH, ну если бы такая строка была гарантированно одна, то достаточно было бы сделать второй массив с размерностью n-1xm, а какой-нибудь метод возвращал бы номер лишней строки. Тогда с простым if'ом можно переписать все элементы, кроме элементов найденной строки
0
7533 / 6396 / 2916
Регистрация: 14.04.2014
Сообщений: 27,859
16.03.2018, 18:51 6
Ну тогда надо дополнительно подсчитать сколько таких строк и при копировании пропускать.
0
1754 / 1346 / 1407
Регистрация: 28.10.2016
Сообщений: 4,267
16.03.2018, 18:54 7
AnAlCH, вроде этого
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
#include <iostream>
#include <ctime>
#include <cstdlib>
 
int IndexMin(int **a, int n) {
    int indmin = 0;
    for (int i = 1; i < n; i++)
        if (a[i][i] < a[indmin][indmin])
            indmin = i;
    return indmin;
}
 
int main() {
    srand(time(NULL));
    int n = 5;
    int **a = new int*[n], **b = new int*[n - 1];
    for (int i = 0; i < n; i++) {
        a[i] = new int[n];
        for (int j = 0; j < n; j++) {
            a[i][j] = -25 + rand() % 51;
            std::cout << a[i][j] << "\t";
        }
        std::cout << "\n";
    }
    std::cout << "New Matrix:\n";
    int indmin = IndexMin(a, n);
    bool boo = false;
    for (int i = 0; i < n - 1; i++) {
        b[i] = new int[n];
        if (i == indmin) boo = !boo;
        for (int j = 0; j < n; j++) {
            if (boo) b[i][j] = a[i + 1][j];
            else b[i][j] = a[i][j];
            std::cout << b[i][j] << "\t";
        }
        std::cout << "\n";
    }
 
    for (int i = 0; i < n; i++) delete[] a[i];
    for (int i = 0; i < n - 1; i++) delete[] b[i];
    delete[] a;
    delete[] b;
    system("pause");
    return 0;
}
0
0 / 0 / 0
Регистрация: 06.01.2018
Сообщений: 28
16.03.2018, 22:13  [ТС] 8
А без функции,можно как-то сделать?
0
1754 / 1346 / 1407
Регистрация: 28.10.2016
Сообщений: 4,267
16.03.2018, 22:23 9
Лучший ответ Сообщение было отмечено AnAlCH как решение

Решение

AnAlCH, можно
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
#include <iostream>
#include <ctime>
#include <cstdlib>
 
int main() {
    srand(time(NULL));
    int n = 5;
    int **a = new int*[n], **b = new int*[n - 1];
    for (int i = 0; i < n; i++) {
        a[i] = new int[n];
        for (int j = 0; j < n; j++) {
            a[i][j] = -25 + rand() % 51;
            std::cout << a[i][j] << "\t";
        }
        std::cout << "\n";
    }
    std::cout << "New Matrix:\n";
    int indmin = 0;
    for (int i = 1; i < n; i++)
        if (a[i][i] < a[indmin][indmin])
            indmin = i;
    bool boo = false;
    for (int i = 0; i < n - 1; i++) {
        b[i] = new int[n];
        if (i == indmin) boo = !boo;
        for (int j = 0; j < n; j++) {
            if (boo) b[i][j] = a[i + 1][j];
            else b[i][j] = a[i][j];
            std::cout << b[i][j] << "\t";
        }
        std::cout << "\n";
    }
 
    for (int i = 0; i < n; i++) delete[] a[i];
    for (int i = 0; i < n - 1; i++) delete[] b[i];
    delete[] a;
    delete[] b;
    system("pause");
    return 0;
}
0
0 / 0 / 0
Регистрация: 06.01.2018
Сообщений: 28
17.03.2018, 00:09  [ТС] 10
Спасибо)
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
17.03.2018, 00:09
Помогаю со студенческими работами здесь

Дан массив R(M,M). Переставить строку с минимальным элементом на главной диагонали со строкой с заданным номер
Дан массив R(M,M). Переставить строку с минимальным элементом на главной диагонали со строкой с...

Дан массив A(N,N) Минимальный элемент главной диагонали поменять местами с минимальным элементом массива
Дан массив A(N,N) Минимальный элемент главной диагонали поменять местами с минимальным элементом...

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

Определить минимальный элемент массива к (5х5).Упорядочить строку с минимальным элементом по убыванию
Определить минимальный элемент массива к (5х5).Упорядочить строку с минимальным элементом по...


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

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

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