Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.80/5: Рейтинг темы: голосов - 5, средняя оценка - 4.80
11 / 11 / 3
Регистрация: 18.12.2011
Сообщений: 112

Массивы:многомерный и одномерный (заменить нулями все отрицательные числа выше главной диагонали)

16.12.2012, 17:38. Показов 1198. Ответов 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
#include <iostream>
using namespace std;
void main()
 
{int i,j,max,jmax,imax;
int matrix [3][3];
cout<<"Input matrix\n";
for(i=0;i<3;i++)
    for(j=0;j<3;j++)
        cin>>*(*(matrix+i)+j);
for(i=0;i<3;i++)
    for(j=i;j<3;j++)
        if(matrix[i][j]<0)
            matrix[i][j]=0;
max=matrix[0][0];
for(i=0;i<3;i++)
    for(j=3-i-1;j<3;j++)
        if(matrix[i][j]>max)
        {max=matrix[i][j];
imax=i;
jmax=j;}
cout<<"max="<<max<<endl;
cout<<"jmax="<<jmax<<endl;
cout<<"imax="<<imax<<endl;
cin.get();
cin.get();
}
правильно написан код?
и да еще вопрос при вводе getch()программа не хочет работать при вводе getchar сразу же закрываеться
и вот массив №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
// 12345.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <conio.h>
#include <iostream>
using namespace std;
void main()
{ const int n=10;
int i,j,k=0,dob,sort;
int A[n],B[n];
for(i=0;i<10;i++)
{cout<<"vvedite A[i]"<<endl;
    cin>>A[i];
if(A[i]<0)
{B[k]=A[i];
 k++;
}
}
for(j=0;j<10;j++)
{if (B[j]!=0)
cout<<B[j]<<" "<<endl;}
for (i=0;i<10;i++)
dob=1;
{if (A[i]>0)
dob+=dob*A[i];
cout<<"dob="<<dob<<endl;}
for (i=1;i<10;i++)
    for (j=0;j<10;j++)
        if(B[i]>B[i+1])
        {sort=B[i]; B[i]=B[i+1]; B[i+1]=sort;}
        cout<<"Sort result"<<endl;
        for (i=0;i<10;i++)
            cout<<B[k]<<" ";
 
getch();
}
Тут задача была перенест все отрицательные числа из массива А в массив В, посчитать произведение всех положительных чисел массива А и отсортировать массив В по возростанию.
Тут явно ошибка массив В выходит за пределы памяти,и почемуто сортируеться не то. Еще при запуске программы когда она переносит отрицательные числа в массив В кроме отрицательных показуеться какоето непонятное число -858993460.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
16.12.2012, 17:38
Ответы с готовыми решениями:

Матрица. Заменить нулями все ее элементы, расположенные на главной диагонали и выше ее
2. Дана действительная квадратная матрица порядка 6. Заменить нулями все ее элементы, расположенные на главной диагонали и выше ее. ...

Дана квадратная матрица. Заменить нулями все ее элементы, расположенные на главной диагонали и выше ее
Дана квадратная матрица порядка N. Заменить нулями все ее элементы, расположенные на главной диагонали и выше ее. Вывести матрицу в...

Дана квадратная вещественная матрица размерности n. Заменить нулями все ее элементы, расположенные на главной диагонали и выше нее
Дана квадратная вещественная матрица размерности n. Заменить нулями все ее элементы, расположенные на главной диагонали и выше нее

7
0 / 0 / 0
Регистрация: 14.12.2012
Сообщений: 9
16.12.2012, 18:23
в первом подключите <conio.h> - getch заработает
0
11 / 11 / 3
Регистрация: 18.12.2011
Сообщений: 112
17.12.2012, 03:04  [ТС]
.................извените но Вы считаете что я настолько глуп?

Добавлено через 2 минуты
Если не понятно то про getch имеется введу вобщем случае а не конкретных программ.

Добавлено через 8 часов 16 минут
тему можно закрывать сам розобрался, с getch проблема осталось ,но его можно заменить другими операторами...
вот код исправленный может кому понадобиться
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
// 12345.cpp: определяет точку входа для консольного приложения.
//
 
#include "stdafx.h"
#include <iostream>
using namespace std;
void main()
{ const int n=10;
int i,j,k=0,sort;
int A[n],B[n]={0,0,0,0,0,0,0,0,0,0};
for(i=0;i<10;i++)
{cout<<"vvedite A[i]"<<endl;
    cin>>A[i];
if(A[i]<0)
{B[k]=A[i];
 k++;
}
}
for(j=0;j<10;j++)
{if (B[j]!=0)
cout<<B[j]<<" "<<endl;}
int dob=1;
for (i=0;i<10;i++)
if (A[i]>0)
{dob*=A[i];}
cout<<"dob="<<dob<<endl;
for (i=0;i<10-1;i++)
    for (j=0;j<10-1;j++)
        if(B[i]>B[i+1])
        {sort=B[i]; B[i]=B[i+1]; B[i+1]=sort;}
        cout<<"Sort result"<<endl;
        for (i=0;i<10;i++)
            cout<<B[i]<<" ";
 
cin.get();
cin.get();
}
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
17.12.2012, 03:13
Цитата Сообщение от ShikiofDevil Посмотреть сообщение
с getch проблема осталось ,но его можно заменить другими операторами...
вот код исправленный может кому понадобиться
Это из-за того, что в потоке остается символ конца строки, поэтому getch его считывал и программа выполнялась далее. Если уберете один cin.get() то получите ту же проблему.

Добавлено через 5 минут
Цитата Сообщение от Кукарача Посмотреть сообщение
в первом подключите <conio.h> - getch заработает
В первом нет getch(), а во втором данный фаил включен
0
11 / 11 / 3
Регистрация: 18.12.2011
Сообщений: 112
17.12.2012, 03:52  [ТС]
Нет.Ошибка заключаеться в другом
1>------ Построение начато: проект: laba2, Конфигурация: Debug Win32 ------
1> laba2.cpp
1>c:\users\devilz\documents\visual studio 2012\projects\laba2\laba2\laba2.cpp(37): error C4996: 'getch': The POSIX name for this item is deprecated. Instead, use the ISO C++ conformant name: _getch. See online help for details.
1> c:\program files\microsoft visual studio 11.0\vc\include\conio.h(131): см. объявление "getch"
========== Построение: успешно: 0, с ошибками: 1, без изменений: 0, пропущено: 0 ==========
вот она собственно
0
Неэпический
 Аватар для Croessmah
18144 / 10728 / 2066
Регистрация: 27.09.2012
Сообщений: 27,026
Записей в блоге: 1
17.12.2012, 04:00
c:\users\devilz\documents\visual studio 2012\projects\laba2\laba2\laba2.cpp(37): error C4996: 'getch': The POSIX name for this item is deprecated.
кхм...
Instead, use the ISO C++ conformant name: _getch. See online help for details.
ну попробуйте тогда
C++
1
_getch();
1
11 / 11 / 3
Регистрация: 18.12.2011
Сообщений: 112
17.12.2012, 04:11  [ТС]
Спасибо,теперь точно можно закрывать.
Да еще вопрос можно както сделать чтобы массив автоматически заполнял пустые ячейки 0?
0
1373 / 596 / 199
Регистрация: 02.08.2011
Сообщений: 2,886
17.12.2012, 04:59
C++
1
int A[n]={0};
Цитата Сообщение от ShikiofDevil Посмотреть сообщение
чтобы массив автоматически заполнял пустые ячейки 0?
Это если именно нулем.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
17.12.2012, 04:59
Помогаю со студенческими работами здесь

[C++] Дана квадратная матрица состоящая из натруальных чисел. Надо заменить нулями элементы, расположенные на главной диагонали и выше её
Напишите пожалуйста код. Очень надо ):)

В матрице заменить нулями все отрицательные элементы над главной диагональю
Помогите написать код - В матрице заменить нулями все отрицательные элементы над главной диагональю

Заменить в матрице все элементы выше главной диагонали числом 2
Дана целочисленная матрица размера NxM. Заменить в данной матрице все элементы выше главной диагонали числом 2.

Матрицы. Отрицательные элементы матрицы, расположенные выше главной диагонали, заменить на квадраты их значений
Отрицательные элементы матрицы (n=6; m=6), расположенные выше главной диагонали, заменить на квадраты их значений. Найти максимальный среди...

Дана действительная квадратная матрица порядка 12. Заменить нулями все её элементы, расположенные на глав-ной диагонали и выше неё.
Дана действительная квадратная матрица порядка 12. Заменить нулями все её элементы, расположенные на глав-ной диагонали и выше неё.


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

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru