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

В матрице найти произведение над главной диагональю,если произведение делится на 3 заменить побочную диагональ 0.

05.12.2010, 19:07. Показов 1958. Ответов 2
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Нужно заменить элементы побочной диагонали нулями,если произведение парных элементов над главной диагональю делится на 3,все сделал кроме замены элементов побочной диагонали нулями,если не сложно подскажите пожалуйста

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
61
62
63
64
65
66
67
#include "stdafx.h"
#include <iostream>
#include <time.h>
#include <iomanip>
#include "conio.h"
#include <math.h>
using namespace std;
int main ()
{
    int i, j, m, n, p=1, k,randu,s;
    setlocale (0,"Rus");
    cout << "\nВведите размер квадратной матрицы:" << endl;
    cout << "n="; cin >>n;
    cout << "m="; cin >>m;
    int **matr = new int *[n];
    //заполнение матрицы
    
    randu=time(NULL);
    for (i=0; i<n; i++)
        matr[i] = new int [m];
    for (int i=0; i<n; i++)
        for (int j=0; j<m; j++ ){
            matr[i][j]=abs((randu) % 11+1);
                            randu*=(randu+101);
               }
        /*Вывод матрицы*/
        for (int i=0; i<n; i++){
         for (int j=0; j<m; j++ ){
            
          cout<<setw(4)<< matr[i][j];
               }
         cout<<"\n";
      }
    /*вывод матрицы*/
    for (i=0; i<n; i++) {
        cout<<"\n\n";
        for (j=0; j<m; j++)         
            cout<< *(matr[i]+j) <<"\t";
    }
    cout<<"\n\n";
    //Вычисление произведения парных элементов над главной диагональю
    for (k=1, i=0; i<n-1; i++, k++) 
        for (j=k; j<m; j++) 
            if (matr[i][j]%2==0)
                p*=matr[i][j];
    cout<<"Произведение парных элементов над главной диагональю="<<p <<"\n";
    /*Если произведение делится на 3 заменяем побочную диагональ 0*/
    if(p%3==0 && p!=0 )
    {
        cout<<"Произведение парных элементов над главной диагональю делится 3="<<p/3<<",замена элементов побочной диагонали нулями"<<endl;
        for (i = 0; i < n; i++) {
        matr[i][i] = 0;
            
        for (j =n-1; j >= 0 ; j--) {
            matr[n-1-j][j] = 0;
        cout<<setw(4)<<matr[i][j];}
 
 
    }   
    }
    else
    {
        cout<<"Произведение парных элементов над главной диагональю не делится 3"<<endl;
    }
    system("pause");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
05.12.2010, 19:07
Ответы с готовыми решениями:

Найти произведение и положительных элементов, расположенные над главной диагональю
Найти произведение и положительных элементов, расположенные над главной диагональю! Это как??????? Главная диагональ?

Найти произведение элементов матрицы, стоящих над главной диагональю
Дан двумерный массив 10на10 заполняется случайным образом Найти произведение элементов стоящих над главной диагональю

Найти произведение отрицательных элементов над главной диагональю матрицы
Массив B задан по формуле B=sin(i+j+0,5).Найти произведение отрицательных элементов над главной диагональю. Помогите пожалуйста на с++.

2
1 / 1 / 1
Регистрация: 18.11.2010
Сообщений: 9
05.12.2010, 19:18
C++
1
2
3
4
5
6
int j=m-1;
for (int i=0, i<n, i++)
{
matr[i][j]=0;
j--;
}
m - кол-во эл-ов в строке
n - в столбце
0
2 / 2 / 1
Регистрация: 05.12.2010
Сообщений: 15
05.12.2010, 20:03  [ТС]
спасибо

Добавлено через 27 минут
переделал,но не могу вывести новую матрицу.......может я что то не правильно делаю??просто уже долго сижу мозг плавится.....поправьте если что то не так...
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
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
/* 4.5.cpp : Среди элементов матрицы, что находятся высше главной диагонали, найти произведение парных элементов */
 
#include "stdafx.h"
#include <iostream>
#include <time.h>
#include <iomanip>
#include "conio.h"
#include <math.h>
using namespace std;
int main ()
{
    int i, j, m, n, p=1, k,randu;
    setlocale (0,"Rus");
    cout << "\nВведите размер квадратной матрицы:" << endl;
    cout << "n="; cin >>n;
    cout << "m="; cin >>m;
    //объявление и заполнение двумерного массива
    int **matr = new int *[n];
    randu=time(NULL);
    for (i=0; i<n; i++)
        matr[i] = new int [m];
    for (int i=0; i<n; i++)
        for (int j=0; j<m; j++ ){
            matr[i][j]=abs((randu) % 11+1);
                            randu*=(randu+101);
               }
        /*Вывод матрицы*/
        for (int i=0; i<n; i++){
         for (int j=0; j<m; j++ ){
            
          cout<<setw(4)<< matr[i][j];
               }
         cout<<"\n";
      }
    /*вывод матрицы*/
    for (i=0; i<n; i++) {
        cout<<"\n\n";
        for (j=0; j<m; j++)         
            cout<< *(matr[i]+j) <<"\t";
    }
    cout<<"\n\n";
    //Вычисление произведения парных элементов над главной диагональю
    for (k=1, i=0; i<n-1; i++, k++) 
        for (j=k; j<m; j++) 
            if (matr[i][j]%2==0)
                p*=matr[i][j];
    cout<<"Произведение парных элементов над главной диагональю="<<p <<"\n";
    /*Если произведение делится на 3 заменяем побочную диагональ 0*/
    if(p%3==0 && p!=0 )
    {
        cout<<"Произведение парных элементов над главной диагональю делится 3="<<p/3<<",замена элементов побочной диагонали нулями"<<endl;
        
        
        j=m-1;
        for (int i=0; i<n, i++;)
        {
        matr[i][j]=0;
        j--;
        } 
        /*Вывод матрицы*/
         
    
        for (int i=0; i<n; i++){
         for (int j=0; j<m; j++ ){
            
          cout<<setw(4)<<matr[i][j];
               }
         cout<<"\n";
      }
    /*вывод матрицы*/
    for (int i=0; i<n; i++) {
        cout<<"\n\n";
        for (int j=0; j<m; j++)         
            cout<< *(matr[i]+j) <<"\t";
    }
    cout<<"\n\n";
 
    }
    
    
    else
    {
        cout<<"Произведение парных элементов над главной диагональю не делится 3"<<endl;
    }
    system("pause");
    return 0;
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
05.12.2010, 20:03
Помогаю со студенческими работами здесь

В квадратной матрице найти произведение отрицательных элементов под главной диагональю
Дали курсовую.Разработать алгоритм заполнения и обработки массива,а также интерфейс программы и программный код в среде VBA Excel.В данной...

Найти минимальное число в матрице и заменить им главную и побочную диагональ
6. Дана матрица nn, заполненная числами. Найти в ней минимальное число и заменить им главную и побочную диагональ матрицы, первую и...

Вычислить произведение элементов над главной диагональю
from math import * def f(k): return 2*sin(2*k)*cos(2*k)-11.6*sin((k/0.4)-1) def g(n): return...

Вычислить произведение элементов над главной диагональю матрицы

Вычислить произведение элементов над главной диагональю матрицы
Вычислить произведение элементов над главной диагональю матрицы и определить их количество.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Подстановка значения реквизита справочника в табличную часть документа
Maks 10.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа "ПланированиеПерсонала", разработанного в конфигурации КА2. Задача: при выборе сотрудника (справочник Сотрудники) в ТЧ документа. . .
Очистка реквизитов документа при копировании
Maks 09.04.2026
Алгоритм из решения ниже применим как для типовых, так и для нетиповых документов на самых различных конфигурациях. Задача: при копировании документа очищать определенные реквизиты и табличную. . .
модель ЗдравоСохранения 8. Подготовка к разному выполнению заданий
anaschu 08.04.2026
https:/ / github. com/ shumilovas/ med2. git main ветка * содержимое блока дэлэй из старой модели теперь внутри зайца новой модели 8ATzM_2aurI
Блокировка документа от изменений, если он открыт у другого пользователя
Maks 08.04.2026
Алгоритм из решения ниже реализован на примере нетипового документа, разработанного в конфигурации КА2. Задача: запретить редактирование документа, если он открыт у другого пользователя. / / . . .
Система безопасности+живучести для сервера-слоя интернета (сети). Двойная привязка.
Hrethgir 08.04.2026
Далее были размышления о системе безопасности. Сообщения с наклонным текстом - мои. А как нам будет можно проверить, что ссылка наша, а не подделана хулиганами, которая выбросит на другую ветку и. . .
Модель ЗдрввоСохранения 7: больше работников, больше ресурсов.
anaschu 08.04.2026
работников и заданий может быть сколько угодно, но настроено всё так, что используется пока что только 20% kYBz3eJf3jQ
Дальние перспективы сервера - слоя сети с космологическим дизайном интефейса карты и логики.
Hrethgir 07.04.2026
Дальнейшее ближайшее планирование вывело к размышлениям над дальними перспективами. И вот тут может быть даже будут нужны оценки специалистов, так как в дальних перспективах всё может очень сильно. . .
Горе от ума
kumehtar 07.04.2026
Эта мне ментальная установка, что вот прямо сейчас, мол, мне для полного счастья не хватает (нужное вписать), и когда я этого достигну - тогда и полный кайф. Одна из самых сильных ловушек на пути. . . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru