Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.75/4: Рейтинг темы: голосов - 4, средняя оценка - 4.75
0 / 0 / 1
Регистрация: 20.11.2013
Сообщений: 26
1

Двумерные.Вычесть минимальный элемент

20.11.2013, 23:39. Показов 736. Ответов 8
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Ребят, не пойму что не так, почему не хочет работать программа. Задача вот в чем: в двумерном массиве нужно найти мин элемент и вычесть его из той строки и того столбца на пересечении которых он находится. Мин элемент я нашел, после присвоил новым аргументам индексы его строки и столбца и с ними сравниваю все элементы массива... вроде все так, но при отладке ничего не происходит..
Помогите, пожалуйста, разобраться!
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
#include <iostream>
int main () {
    int n,m;
    std::cout<<"Vvedite kolichestvo strok:";
    std::cin>>n;
    std::cout<<"Vvedite kolichestvo stolbcov:";
    std::cin>>m;
    int i,j,min;
    int nom_str, nom_stl; 
    int **a=new int*[n];
    for (i=0; i<n; i++)
    a[i] = new int[m];
    std::cout<<"Vvedite elementi massiva:"<<std::endl;
    for (i=0; i<n; i++ )
        for (j=0; j<m; j++)
            std::cin>>a[i][j];
    for (i=0; i<n; i++ ) {
        for (j=0; j<m; j++) 
            std::cout<<a[i][j]<<" ";
        std::cout<<"\n";
    }
    min = a[0][0];
    for ( i = 0; i < n; i++) 
        for ( j = 0; j < m; j++) 
            if(min > a[i][j]) {
                min = a[i][j];
                nom_str = i; 
                nom_stl = j; 
                if(a[i][j]==a[nom_str][j]) a[i][j]=i-min;
                else if (a[i][j]==a[i][nom_stl]) a[i][j]=j-min;
            }
                  std::cout <<"Min element " << min << std::endl;
                  std::cout << "Index " << "[" << nom_str << "][" << nom_stl << "]" << std::endl;
                  std::cout<<"\n";
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
20.11.2013, 23:39
Ответы с готовыми решениями:

Минимальный элемент каждой колонки вычесть из данной колонки(со строками работает)
#include &lt;iostream&gt; #include &lt;algorithm&gt; #include &lt;cmath&gt; using namespace std; int main() { setlocale(LC_ALL,...

Найти минимальный элемент матрицы и вычесть его величину из окружающих его элементов
Дана матрица (N+15)x(N+15), найти минимальный элемент и вычесть его величину из окружающих его элементов. Матрицу рассматривать как...

Из положительных элементов массива вычесть первый элемент, из остальных - второй элемент
Дан массив L(7). Из положительных элементов вычесть первый элемент, из остальных - второй элемент. Вывести новый массив на печать.2 3 -4 ...

8
 Аватар для Folko
267 / 255 / 27
Регистрация: 27.09.2013
Сообщений: 876
Записей в блоге: 1
20.11.2013, 23:44 2
Вamboo, в смысле при отладке ничего не происходит, окошко с результатами не появляется? И по моему у вас алгоритм не так, как нужно работает...
1
0 / 0 / 1
Регистрация: 20.11.2013
Сообщений: 26
20.11.2013, 23:46  [ТС] 3
Нет, окошко появляется, все элементы ввожу, находит минимальный, а дальше ничего не делает, будто кода и нет далее
0
 Аватар для Folko
267 / 255 / 27
Регистрация: 27.09.2013
Сообщений: 876
Записей в блоге: 1
20.11.2013, 23:51 4
Вamboo, то есть вывел минимальный и все? Закрылся?
0
0 / 0 / 1
Регистрация: 20.11.2013
Сообщений: 26
20.11.2013, 23:55  [ТС] 5
Folko, да
0
 Аватар для Folko
267 / 255 / 27
Регистрация: 27.09.2013
Сообщений: 876
Записей в блоге: 1
20.11.2013, 23:59 6
Вamboo, в конце функции main допишите system("pause");
0
0 / 0 / 1
Регистрация: 20.11.2013
Сообщений: 26
21.11.2013, 00:16  [ТС] 7
Folko, ничего не изменилось..
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
#include <iostream>
int main () {
    int n,m;
    std::cout<<"Vvedite kolichestvo strok:";
    std::cin>>n;
    std::cout<<"Vvedite kolichestvo stolbcov:";
    std::cin>>m;
    int i,j,min;
    int nom_str, nom_stl; 
    int **a=new int*[n];
    for (i=0; i<n; i++)
    a[i] = new int[m];
    std::cout<<"Vvedite elementi massiva:"<<std::endl;
    for (i=0; i<n; i++ )
        for (j=0; j<m; j++)
            std::cin>>a[i][j];
    for (i=0; i<n; i++ ) {
        for (j=0; j<m; j++) 
            std::cout<<a[i][j]<<" ";
        std::cout<<"\n";
    }
    min = a[0][0];
    for ( i = 0; i < n; i++) 
        for ( j = 0; j < m; j++) 
            if(min > a[i][j]) {
                min = a[i][j];
            }
                  std::cout <<"Min element " << min << std::endl;
                  std::cout << "Index " << "[" << nom_str << "][" << nom_stl << "]" << std::endl;
        nom_str = i; 
                nom_stl = j; 
                if(a[i][j]==a[nom_str][j]) a[i][j]=i-min;
                else if (a[i][j]==a[i][nom_stl]) a[i][j]=j-min;
                for (i = 0; i < M; i++)
                {
        for (j = 0; j < N; j++)
        {
            cout <<setw(4)<< mas[i][j] << " ";
        }
        cout << '\n';
    }
                system("pause")
}
Добавлено через 12 минут
конечно же в 38 строке не "mas" а "a"
но все же не работает..
0
 Аватар для Folko
267 / 255 / 27
Регистрация: 27.09.2013
Сообщений: 876
Записей в блоге: 1
21.11.2013, 00:28 8
Вamboo, запустил у себя, вы еще и библиотеку iomanip не подключили, а используете setw(). Попробовал запустить у себя, у вас программа завершается на
C++
1
2
if(a[i][j]==a[nom_str][j]) a[i][j]=i-min;
                else if (a[i][j]==a[i][nom_stl]) a[i][j]=j-min;
Да и вообще мне что то не нравится ваш алгоритм, правда. По хорошему нужно сначала просто найти минимальный элемент, а потом в отдельном цикле вычесть его
И да, пропишите вы using namespace std; , неужели вам в кайф к каждому cin/cout приписывать std::?
1
0 / 0 / 1
Регистрация: 20.11.2013
Сообщений: 26
21.11.2013, 15:46  [ТС] 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
#include <iostream>
#include <iomanip>
int main () {
    using namespace std;
    int n,m;
    std::cout<<"Vvedite kolichestvo strok:";
    std::cin>>n;
    std::cout<<"Vvedite kolichestvo stolbcov:";
    std::cin>>m;
    int i,j,min;
    int nom_str, nom_stl; 
    int **a=new int*[n];
    for (i=0; i<n; i++)
    a[i] = new int[m];
    cout<<"Vvedite elementi massiva:"<<endl;
    for (i=0; i<n; i++ )
        for (j=0; j<m; j++)
            cin>>a[i][j];
    for (i=0; i<n; i++ ) {
        for (j=0; j<m; j++) 
            cout<<a[i][j]<<" ";
        cout<<"\n";
    }
    min = a[0][0];
    for ( i = 0; i < n; i++) 
        for ( j = 0; j < m; j++) 
            if(min > a[i][j]) {
                min = a[i][j];
            }
            cout <<"Min element " << min << endl;
            cout << "Index " << "[" << nom_str << "][" << nom_stl << "]" << endl;
                  for ( i = 0; i < n; i++) 
                      for ( j = 0; j < m; j++) {
                          min=a[nom_str][nom_stl]; 
                          if(a[i][j]==a[nom_str][j]){ 
                              a[i][j]=a[i][j]-min;
                          }
                          else if (a[i][j]==a[i][nom_stl]) {
                              a[i][j]=a[i][j]-min;
                          }
                      }
                      for (i = 0; i < M; i++)
                {
                    for (j = 0; j < N; j++)
                    {
                        cout <<setw(4)<< a[i][j] << " ";
                        cout << '\n';
                    }
                }
                system("pause")
                      }
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
21.11.2013, 15:46
Помогаю со студенческими работами здесь

Решить уравнение p*x2+d*x+r=0, где p - минимальный элемент матрицы A; d –минимальный элемент матрицы B; r - минимальный элемент матрицы C.
Заданы три матрицы A, B, C. Решить уравнение p*x2+d*x+r=0, где p - минимальный элемент матрицы A; d –минимальный элемент матрицы B; r -...

Вычесть из положительных элементов массива элемент с номером k1, а к отрицательным прибавить элемент с номером k2, нулевые элементы оставить без измен
Вычесть из положительных элементов массива элемент с номером k1, а к отрицательным прибавить элемент с номером k2, нулевые элементы...

Двумерные массивы. Найти новый одномерный массив, максимальный элемент, заменить третий элемент
Помогите пожалуйста написать хотя бы одну из этих программ: Дана матрица А(5,5) 1.Найти новый одномерный массив С из сумм элементов...

Из всех положительных элементов вычесть элемент с номером k1, из остальных — элемент с номером k2
Дан массив вещественных чисел. Из всех положительных элементов вычесть элемент с номером k1, из остальных — элемент с номером k2.Помогите...

Вычесть из всех элементов массива наибольший элемент
Нужно из всех элементов массива вычесть наибольший. Пока что нашла только наибольший, а как вычесть, не понимаю. #include...


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

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

Редактор формул (кликните на картинку в правом углу, чтобы закрыть)
Новые блоги и статьи
Java Record или Kotlin Data Class: что лучше для неизменяемых данных
Wired 04.03.2025
Java Record и Kotlin Data Class - средства для работы с неизменяемыми структурами данных, каждое из которых предлагает свой уникальный подход к решению этой задачи. История их появления весьма. . .
Создание производительны­­х API с Java и gRPC
Wired 04.03.2025
В разработке производительность и масштабируемость микросервисных приложений играют ключевую роль. Традиционные REST API, несмотря на свою популярность и простоту, не всегда способны обеспечить. . .
Что нового в JDK 24
Wired 04.03.2025
JDK 24 знаменует собой значительный скачок в развитии Java, внося фундаментальные улучшения в производительность, безопасность и удобство разработки. Релиз включает множество революционых изменений,. . .
Разработка блокчейн с использованием Java: смарт-контракты и dApp
Wired 04.03.2025
Современная блокчейн-разработка на Java предоставляет разработчикам широкий спектр возможностей. В отличие от Solidity, который ограничен экосистемой Ethereum, Java позволяет создавать как. . .
WebAssembly в Kubernetes
stackOverflow 03.03.2025
В современной экосистеме облачных технологий WebAssembly (Wasm) становится все более значимым компонентом, предлагая уникальный подход к выполнению кода в распределенных системах. Эта технология. . .
GitHub Actions или Jenkins: Выбираем CI/CD платформу
stackOverflow 03.03.2025
Непрерывная интеграция и развертывание (CI/ CD) изменили подход к разработке программного обеспечения, превратив его в бесшовный процесс от написания кода до развертывания в продакшн. GitHub Actions и. . .
Автоматизация тестирования Pull Request в Kubernetes: Интеграция с GitHub Actions и GKE
stackOverflow 03.03.2025
Масштабные проекты с использованием Kubernetes требуют надежной системы тестирования изменений перед их внедрением в продакшн-среду. Традиционный подход с ручной проверкой Pull Request не справляется. . .
Tестирование Pull Request в Kubernetes с помощью vCluster
stackOverflow 03.03.2025
При работе с микросервисной архитектурой критически важно обеспечить качественное тестирование каждого изменения перед его слиянием в основную кодовую базу. Однако тестирование Pull Request в. . .
Использование пакета Context в Golang
bytestream 03.03.2025
Управление параллельными процессами в современных приложениях - сложная задача, особенно когда речь идет о микросервисной архитектуре и распределенных системах. Пакет context в Go - это гибкое. . .
WebAssembly и Go: Работа с DOM и обработка ошибок
bytestream 03.03.2025
WebAssembly представляет собой технологию, позволяющую запускать низкоуровневый код в браузере практически на нативной скорости. Особенно интересные возможности открываются при использовании. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru