Реализовать в виде класса набор методов для выполнения след.операций с квадратными матрицами размерность n*n - C#

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

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

Реализовать в виде класса набор методов для выполнения след.операций с квадратными матрицами размерность n*n: 1) Сложение двух матриц 2) умножение одной матрицы на другую 3) нахождение суммы элементов на главной диагонали

Решение задачи: «Реализовать в виде класса набор методов для выполнения след.операций с квадратными матрицами размерность n*n»

textual
Листинг программы
  1. using System;
  2. namespace ConsoleApplication5
  3. {
  4.     class Program
  5.     {
  6.         static void Main(string[] args)
  7.         {
  8.             Console.WriteLine("Введите n:");
  9.             int n = int.Parse(Console.ReadLine());
  10.  
  11.             int[,] massiv = new int[n, n];
  12.             Console.WriteLine("Заполните первую матрицу");
  13.             for (int i = 0; i < n; i++)
  14.             {
  15.                 for (int j = 0; j < n; j++)
  16.                 {
  17.                     Console.Write("Введите элемент [{0},{1}] ",i,j);
  18.                     massiv[i, j] = int.Parse(Console.ReadLine());
  19.                 }
  20.             }
  21.  
  22.             int[,] massiv1 = new int[n, n];
  23.             Console.WriteLine("Заполните вторую матрицу");
  24.             for (int i = 0; i < n; i++)
  25.             {
  26.                 for (int j = 0; j < n; j++)
  27.                 {
  28.                     Console.Write("Введите элемент [{0},{1}] ", i, j);
  29.                     massiv1[i, j] = int.Parse(Console.ReadLine());
  30.                 }
  31.             }
  32.             Console.WriteLine("Матрица 1");
  33.             for (int i = 0; i < n; i++)
  34.             {
  35.                 for (int j = 0; j < n; j++)
  36.                 {
  37.                     Console.Write(massiv[i, j] + " ");
  38.                 }
  39.                 Console.WriteLine();
  40.             }
  41.  
  42.             Console.WriteLine("Матрица 2");
  43.             for (int i = 0; i < n; i++)
  44.             {
  45.                 for (int j = 0; j < n; j++)
  46.                 {
  47.                     Console.Write(massiv1[i, j] + " ");
  48.                 }
  49.                 Console.WriteLine();
  50.             }
  51.  
  52.             Massiv obj = new Massiv();
  53.             int [,] massiv2 = obj.Addition(massiv,massiv1);
  54.             Console.WriteLine("Сложенные матрицы");
  55.             for(int i=0; i < n; i++)
  56.             {
  57.                 for (int j = 0; j < n; j++)
  58.                 {
  59.                     Console.Write(massiv2[i,j]+" ");
  60.                 }
  61.                 Console.WriteLine();
  62.             }
  63.             int[,] massiv3 = obj.Multiplication(massiv, massiv1);
  64.             Console.WriteLine("Умноженные матрицы");
  65.             for (int i = 0; i < n; i++)
  66.             {
  67.                 for (int j = 0; j < n; j++)
  68.                 {
  69.                     Console.Write(massiv3[i, j]+" ");
  70.                 }
  71.                 Console.WriteLine();
  72.             }
  73.             int sum = obj.Summa(massiv);
  74.             int sum1 = obj.Summa(massiv1);
  75.             Console.WriteLine("Сумма элементов главной диагонали первой матрцы {0} второй матрицы {1}",sum,sum1);
  76.             Console.ReadKey();
  77.         }
  78.     }
  79.  
  80.     class Massiv
  81.     {    
  82.         public int[,] Addition(int[,] massiv,int[,] massiv1)
  83.         {
  84.             int[,] resMassiv = new int[massiv.Length, massiv1.Length];
  85.             for (int i = 0; i < massiv1.GetLength(0); i++)
  86.                 for (int j = 0; j < massiv1.GetLength(1); j++)
  87.                     resMassiv[i, j] = massiv[i, j] + massiv1[i, j];
  88.             return resMassiv;
  89.         }
  90.  
  91.         public int[,] Multiplication(int[,] massiv, int[,] massiv1)
  92.         {
  93.             int[,] resMassiv = new int[massiv.Length, massiv1.Length];
  94.             for (int i = 0; i < massiv1.GetLength(1); i++)
  95.             {
  96.                 for (int j = 0; j < massiv1.GetLength(0); j++)
  97.                 {
  98.                     resMassiv[i, j] = 0;
  99.                     for (int k = 0; k < massiv1.GetLength(0); k++)
  100.                     {
  101.                         resMassiv[i, j] += massiv[i, k] * massiv1[k, j];
  102.                     }
  103.                 }
  104.             }
  105.             return resMassiv;
  106.         }
  107.         public int Summa(int [,] massiv)
  108.         {
  109.             int sum = 0;
  110.             for (int i = 0; i < massiv.GetLength(0); ++i)
  111.                 sum += massiv[i, i];
  112.             return sum;
  113.         }
  114.     }
  115. }

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


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

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

8   голосов , оценка 4.75 из 5

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

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

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