Форум программистов, компьютерный форум, киберфорум
Наши страницы

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
NSLANDE
14 / 14 / 3
Регистрация: 11.12.2010
Сообщений: 42
#1

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

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

Дана квадратная матрица А(N, N).Составьте программу, определяющую, является ли данная матрица симметричной или нет. Если матрица симметрична, программа должна обнулить главную диагональ. Из квадратных корней абсолютных величин элементов матрицы сформируйте одномерный массив и отсортируйте его по убыванию методом пузырька (Bubble Sort). Выведите на экран исходную матрицу, преобразованную матрицу и отсортированный массив.
Ввод, вывод, сортировка сделать в функции
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
25.12.2012, 18:45
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Симметричность матрицы (C++):

симметричность матрицы - C++
мне нужно проверить, является ли квадратная матрица симметричной, относительно главной диагонали. Как мне составить условие, чтобы я не...

Симметричность матрицы - C++
#include "stdafx.h" #include <iostream> #include <conio.h> #include <iomanip> #include "MyCrt.cpp" using namespace std; int...

Проверка квадратной матрицы на симметричность - C++
Помогите сделать программу, вот мой код: #include "stdafx.h" #include "stdio.h" #include "conio.h" int main() {int A,i,j,B,n; ...

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

Симметричность массива - C++
Никак не могу дорубить как сделать. подскажите плиз Дан массив из К символов. Определить симметричен ли он, читается ли он одинаково...

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

1
asidorchenko
379 / 205 / 25
Регистрация: 09.04.2012
Сообщений: 635
28.12.2012, 10:53 #2
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
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
28.12.2012, 10:53
Привет! Вот еще темы с ответами:

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

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

Проверка на симметричность слова - C++
void main() { char line; printf(&quot;vvedite stroku\n&quot;); scanf(&quot;%s&quot;,line); for (int i=strlen(line)-1,j=0; i!=strlen(line)/2; i--,j++)...

Проверить k строку массива N*M на симметричность - C++
Проверить k строку массива N*M на симметричность int begin=0,end=m; char polindrom=true; for(int i=begin;i&lt;end;i++){ ...


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

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

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.