Найти произведение положительных элементов, расположенных ниже главной диагонали матрицы - C (СИ)

Узнай цену своей работы

Формулировка задачи:

Проблема в том, что если нет положительных элементов, то выводит присвоенную единицу. Как исправить? Ввести матрицу размером NxM. Память для массива выделить динамически. Выполнить в соответствии с номером варианта индивидуальное задание и вывести на экран исходные данные и полученный результат. Предусмотреть в программе использование функции пользователя. Определить произведение положительных элементов, расположенных ниже главной диагонали матрицы.
Листинг программы
  1. #include <iostream.h>
  2. #include <iomanip.h>
  3. #include <math.h>
  4. void Pro (int**,int,int*);
  5. int main()
  6. {
  7. int **a, i, j, n, x=1;
  8. cout << "Vvedite razmer massiva A:\n";
  9. cin >> n ;
  10. a = new int*[n];
  11. for(i=0; i<n; i++)
  12. a[i] = new int[n];
  13. cout << "\nVvedite massiv A:\n";
  14. for (i=0; i<n; i++)
  15. for (j=0; j<n; j++)
  16. {
  17. cout << "Vvedite a[" << i << "][" << j << "]: " ;
  18. cin >> a[i][j];
  19. }
  20. cout << "\nMassiv A:\n";
  21. for (i=0; i<n; i++)
  22. {
  23. for (j=0; j<n; j++)
  24. cout << setw (9) << a[i][j];
  25. cout << endl;
  26. }
  27. Pro (a, n, &x);
  28. cout << "proizvedenie = " << x;
  29. cout << endl;
  30. for(i=0; i<n; i++)
  31. delete [] a[i];
  32. delete []a;
  33. a = NULL;
  34. return 0;
  35. }
  36. void Pro (int **a, int n, int *x)
  37. {
  38. int i, j;
  39. for (i=0; i<n; i++)
  40. {
  41. for (j=0; j<i; j++)
  42. {
  43. if(a[i][j]>0)
  44. {
  45. *x*=a[i][j];
  46. }
  47. }
  48. }
  49. }

Решение задачи: «Найти произведение положительных элементов, расположенных ниже главной диагонали матрицы»

textual
Листинг программы
  1. ...
  2. int tmp = 0;
  3. Pro (a, n, &x);
  4. if (tmp == 0) x = 0;
  5. ...  
  6. }
  7.  
  8. void Pro (int **a, int n, int *x)
  9. {
  10.     int i, j;
  11.  
  12.     for (i=0; i<n; i++)
  13.     {
  14.         for (j=0; j<i; j++)
  15.         {
  16.             if(a[i][j]>0)
  17.             {
  18.                 *x*=a[i][j];
  19.                 *tmp = 1;
  20.             }
  21.         }
  22.     }
  23. }

Объяснение кода листинга программы

В данном коде происходит следующее:

  1. В функции main инициализируется переменная tmp со значением 0.
  2. Вызывается функция Pro с передачей в нее указателя на матрицу a, размер матрицы n и указатель на переменную x.
  3. Внутри функции Pro инициализируются две переменные i и j для цикла.
  4. Затем, с помощью вложенных циклов, происходит перебор всех элементов матрицы a.
  5. Если элемент a[i][j] больше нуля, то произведение этого элемента и текущего значения переменной x присваивается переменной tmp.
  6. Переменная tmp инициализируется значением 1.
  7. После завершения циклов, значение переменной tmp проверяется на равенство 0.
  8. Если tmp равно 0, то значение переменной x присваивается 0.
  9. Функция Pro возвращает управление в функцию main.
  10. Значение переменной x выводится на экран.

ИИ поможет Вам:


  • решить любую задачу по программированию
  • объяснить код
  • расставить комментарии в коде
  • и т.д
Попробуйте бесплатно

Оцени полезность:

13   голосов , оценка 3.769 из 5

Нужна аналогичная работа?

Оформи быстрый заказ и узнай стоимость

Бесплатно
Оформите заказ и авторы начнут откликаться уже через 10 минут
Похожие ответы