Составить программу обработки матрицы размерности NxN.Ввод,вывод матрицы и оформить в...

0 голосов
96 просмотров

Составить программу обработки матрицы размерности NxN.Ввод,вывод матрицы и оформить в виде процедур или функций. Выполнить программу для N=3. Определить имеются ли равные столбцы в матрице(если да то сколько)


Информатика (105 баллов) | 96 просмотров
0

Я не понял: зачем выводить матрицу, если её сначала вводить?

Дано ответов: 2
0 голосов
Правильный ответ

/*задача дурацкая для n > 3, ибо не понятно, что делать:
1) разбить все столбцы на группы одинаковых столбцов и посчитать внутри них число пар. Затем суммировать.
2) разбить столбцы на группы одинаковых столбцов и суммировать количество элементов в каждой из групп, если оно больше 1. То есть найти количество столбцов, для которых среди других столбцов найдется хотя бы один идентичный ему
3) разбить столбцы на группы одинаковых столбцов и вывести количество элементов в каждой группе, если оно больше 1.
Для n=3 дело проще, потому что таких групп максимум одна, поэтому тут, по сути, неоднозначности не возникает (за исключением того, что в первом пункте...)
В общем, решил делать как во втором пункте. Ответ в любом случае будет верным.*/
#include
using namespace std;
int n, result = 0;
int **ar;//указатель на указатель для создания динамического двумерного массива
bool *Flag;//указатель на первый элемент массива флагов
void create(int n)//создание динамического массива
{
   ar = new int*[n];
   for (int i = 0; i < n; i++)
      ar[i] = new int[n];
   Flag = new bool[n];
   for (int i = 0; i < n; i++)
      Flag[i] = false;
}
void inp(int n) //ввод элементов массива
{
   cout << "Input rows of matrix:\n";<br>   for (int i = 0; i < n; i++)
   {
      cout << i + 1 << ": ";<br>      for (int j = 0; j < n; j++)
         cin >> ar[i][j];
   }
}
void outp(int n) //вывод элементов массива
{
   cout << "Elements of matrix:\n";<br>   for (int i = 0; i < n; i++)
   {
      for (int j = 0; j < n; j++)
         cout << ar[i][j] << " ";<br>      cout << endl;<br>   }
}
bool isEqual(int n, int j1, int j2)//проверка на равенство столбцов
{
   bool res = true;
   for (int i = 0; i < n; i++)
   {
      if (ar[i][j1] != ar[i][j2])
      {
         res = false;
         break;
      }
   }
   if (res)//если столбцы равны
    Flag[j2] = true; /*отмечаем столбец как просмотренный, чтобы в следующий раз его не сравнивать с другими столбцами*/
   return res;
}
void calculate(int n)//считаем количество совпадающих столбцов
{
   int k = 1;
   for (int j1 = 0; j1 < n; j1++)
    if (!Flag[j1])
    {
      k = 1;
      for (int j2 = j1 + 1; j2 < n; j2++)
       if (!Flag[j2] && isEqual(n, j1, j2))
          k++;
      if (k > 1)//имеется k одинаковых стобцов по типу столбца j1
         result += k;//плюсует к итоговому результату
    }
}
int main(){
   cout << "Input n: ";<br>   cin >> n;
   create(n);
   inp(n);//ввод массива
   outp(n);//вывод массива
   calculate(n);//расчет того, что требуется
   if (result > 0)/*количество столбцов, которые совпадают, по крайней мере, с одним из других столбцов*/
      cout << "The number of columns, coinciding with at least one other column, is " << result << endl;<br>   else //все столбцы разные
      cout << "There is no matching columns\n";<br>   return 0;
}

(16.7k баллов)
0

Выполнить программу для N=3

0

В задание написано равно, а не больше(

0

т.е.3х3

0

"задача дурацкая для n > 3, ибо не понятно, что делать:" - если Вам непонятно, то это еще не повод объявлять задачу "дурацкой". На самом деле все понятно для любого целочисленного N, и в частности, для N=3, как предлагается сделать в контрольном решении.

0

Ну и что выводить для N > 3? Ну, допустим, N=9. Равными столбцами являются 1,2,3 и 4,5,6,7 отдельно. В этом случае будет две группы с равными столбцами размером 3 и 4. Оставшиеся два столбца в единственном экземпляре. Можно вывести два числа: 3 и 4. Или можно вывести число столбцов, которые имеют с какими-то другими столбцами идентичность. В этом случае выведется одно число 7.

0

у нас же N=3 а не больше

0

это да)

0

Читайте задание внимательно!!! "Составить программу обработки матрицы размерности NxN. ... Выполнить программу для N=3". Т.е. составить для любого N, а выполнить для N=3. Если бы речь шла только о 3х3, так и писали бы в условии без всяких N.

0 голосов

// PascalABC.NET 3.1, сборка 1250 от 28.05.2016
procedure MatInput(a:array[,] of integer);
begin
  Writeln('Вводите элементы матрицы построчно, в конце нажимая Enter');
  for var i:=0 to Length(a,0)-1 do begin
    Write(i+1,': ');
    for var j:=0 to Length(a,1)-1 do Read(a[i,j]);
    end
end;

procedure MatPrint(a:array[,] of integer);
begin
  for var i:=0 to Length(a,0)-1 do begin
    for var j:=0 to Length(a,1)-1 do Print(a[i,j]);
    Writeln
    end
end;

function IsEqual(a:array[,] of integer; j1,j2:integer;
  flag:array of boolean):boolean;
// равны ли столбцы с индексами j1 и j2
begin
  if flag[j2]=False then begin
    Result:=True;
    for var i:=0 to Length(a,0)-1 do
      if a[i,j1]<>a[i,j2] then begin Result:=False; Break end;
    flag[j2]:=Result
    end
end;

begin
  var n:=ReadInteger('Задайте число строк (столбцов) матрицы:');
  var a:array[,] of integer;
  var m:=ArrFill(n,False);
  SetLength(a,n,n);
  MatInput(a);
  Writeln('*** Принятая матрица ***');
  MatPrint(a);
  var k:=1;
  for var i:=0 to n-2 do
    for var j:=i+1 to n-1 do
      if IsEqual(a,i,j,m) then Inc(k);
  if k>1 then Writeln('Количество совпадающих столбцов равно ',k)
  else Writeln('нет совпадающих столбцов')
end.

Тестовое решение
Задайте число строк (столбцов) матрицы: 3
Вводите элементы матрицы построчно, в конце нажимая Enter
1: 1 2 2
2: 3 5 5
3: 2 2 2
*** Принятая матрица ***
1 2 2
3 5 5
2 2 2
Количество совпадающих столбцов равно 2

(142k баллов)
0

а Вы можете ее помочь написать только в С++?