14 / 14 / 7
Регистрация: 11.12.2010
Сообщений: 42
1

Симметричность матрицы

25.12.2012, 18:45. Показов 2163. Ответов 1
Метки нет (Все метки)

Дана квадратная матрица А(N, N).Составьте программу, определяющую, является ли данная матрица симметричной или нет. Если матрица симметрична, программа должна обнулить главную диагональ. Из квадратных корней абсолютных величин элементов матрицы сформируйте одномерный массив и отсортируйте его по убыванию методом пузырька (Bubble Sort). Выведите на экран исходную матрицу, преобразованную матрицу и отсортированный массив.
Ввод, вывод, сортировка сделать в функции
__________________
Помощь в написании контрольных, курсовых и дипломных работ, диссертаций здесь
0
Лучшие ответы (1)
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
25.12.2012, 18:45
Ответы с готовыми решениями:

Симметричность матрицы
#include "stdafx.h" #include <iostream> #include <conio.h> #include <iomanip> #include...

Проверить строки матрицы на симметричность
Задана матрица размером NxM. Получить массив B, присвоив его k-му элементу значение 1, если k-я...

Проверка квадратной матрицы на симметричность
Помогите сделать программу, вот мой код: #include "stdafx.h" #include "stdio.h" #include...

Определить симметричность матрицы испльзуя указатели
Задание, определить симметричность матрицы с помощью указателей. Не могу никак разобраться с...

1
387 / 214 / 102
Регистрация: 09.04.2012
Сообщений: 635
28.12.2012, 10:53 2
Лучший ответ Сообщение было отмечено NSLANDE как решение

Решение

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
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
#include <stdio.h>
#include <stdlib.h>
#include <time.h>
#include <math.h>
 
void create_matrix(int*** A, int N);
void delete_matrix(int** A, int N);
void initialize_matrix(int** A, int N);
void print_matrix(int** A, int N);
int is_symmetric_matrix(int** A, int N);
void null_main_diagonal(int** A, int N);
void print_array(float* a, int n);
void bubble_sort_array(float* a, int n);
float* form_array(int** A, int N);
 
int main()
{
int N;
int** A;
int symm;
 
A = NULL;
N = 5;
symm = 0;
 
create_matrix(&A, N);
initialize_matrix(A, N);
print_matrix(A, N);
symm = is_symmetric_matrix(A, N); 
 
if (symm)
 null_main_diagonal(A, N);
 
print_matrix(A, N);
 
float* arr = form_array(A, N);
print_array(arr, N*N); 
printf("\n");
bubble_sort_array(arr, N*N); 
print_array(arr, N*N);  
printf("\n");
 
delete_matrix(A, N); A = NULL; 
delete [] arr; arr= NULL;
 
return 0;
}
 
void create_matrix(int*** A, int N)
{
 int i;
 (*A)=new int*[N];
 for(i=0;i<N;i++) 
  (*A)[i] = new int[N]; 
}
 
void delete_matrix(int** A, int N)
{
 int i;
 for(i=0;i<N;i++) 
  delete [] A[i]; 
 
 delete[] A;
 
}
 
void initialize_matrix(int** A, int N)
{
 int i, j;
 srand(time(0));
 for(i=0;i<N;i++)
  for(j=0;j<N;j++)
   A[i][j] = rand()%9;
}
 
void print_matrix(int** A, int N)
{
 int i, j;
 for(i=0;i<N; i++)
 {
  for(j=0;j<N;j++)
   printf("%d " , A[i][j]);
  printf("\n");
 }
}
 
 
int is_symmetric_matrix(int** A, int N)
{
 int i, j;
 for( i = 0; i < N; i++)
  for(j = i+1; j < N; j++)
    if (A[i][j] != A[j][i])
     return 0; 
 return 1;
}
 
 
void null_main_diagonal(int** A, int N)
{
 int i;
 for(i=0;i<N;i++)
  A[i][i] = 0;
}
 
void print_array(float* a, int n)
{
 int i;
 for(i=0;i<n; i++)
  printf("%.1f ", a[i]);
}
 
float* form_array(int** A, int N)
{
 int i, j, k;
 float* arr;
 arr = new float[N*N];
 k = 0;
 for(i=0;i<N;i++) 
  for(j=0;j<N;j++)  
    arr[k++] = sqrt((float)abs(A[i][j]));
 
 return arr;
}
 
void bubble_sort_array(float* a, int n)
{
 int i,j;
 float tmp;
 for(i = 0; i < n; i++) 
 {
  for(j = i + 1; j < n; j++)
  {
    if (a[j]>a[i])
    {
      tmp = a[i];
      a[i] = a[j];
      a[j] = tmp;
    }
  }
 }
}
0
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
28.12.2012, 10:53
Помогаю со студенческими работами здесь

Проверить симметричность матрицы относительно главной и побочной диагонали
Дана квадратная целочисленная матрица. Проверить, является ли она симметричной относительно...

Проверьте симметричность
Проверить матрицу на симметричность.Да я знаю такие задачи уже были.Но я хочу именно свой код.Не...

симметричность строки на С++
Описать рекурсивную функцию, проверяющую, является ли симметричной часть строки s, начинающаяся i-м...

Симметричность массива
задание такое: Задан массив из k символов. Определить, симметричен ли он, т. е. чита-ется ли он...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2022, CyberForum.ru