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

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

Войти
Регистрация
Восстановить пароль
 
Рейтинг: Рейтинг темы: голосов - 13, средняя оценка - 4.92
Jiton
2 / 2 / 1
Регистрация: 09.12.2008
Сообщений: 14
#1

Симметричная квадратная матрица - C++

23.06.2009, 20:52. Просмотров 1810. Ответов 4
Метки нет (Все метки)

"Симметричная квадратная матрица А порядка n задана последовательностью n(n+1)/2 чисел, аналогично правой треугольной матрице. Кроме этой последовательности дан вектор b с n элементами. Найти вектор Ab."

Есть решение похожей задачи суть её такая же, только элементы под главной матрицей равны нулю, а у меня матрица симметричная.

и уменя такая просьба можете ли пепредлать, или направьте на верный путь как заполнить симметричную матрицу.
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
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
#include "stdafx.h"
#include <conio.h>
#include <math.h>
#include <stdio.h>
#include <iostream>
#include <windows.h>
 
char * r(char * txt)
{
 static char buf[1024];
 CharToOemA(txt,buf);
 return buf;
}
 
 
#pragma hdrstop
void vvodM(float*C,int k, int n);     
void vvod(float*C,int n);     
void func(float *, float *, float *C, int n, int k);
void vyvod(float *C, int n);                        
void kontrol(float *C, int k, int n);     
float zachita();
int zachita_int();
//---------------------------------------------------------------------------
 
#pragma argsused
int main(int argc, char* argv[])
{int n=0,k=0;
 float *A=NULL,*b=NULL,*Umn=NULL;        
 printf(r("Введите размерность матрицы А и вектора b  n="));
 n = zachita_int();//scanf("%d",&n);
 b=new float [n];             
 k=(n+1)*n/2;
 A=new float [k];             
 printf(r("\n Введите последовательность матрицы A:"));
 vvodM(A,k,n);
 printf(r("\n Введите вектор b:"));
 vvod(b,n);
 kontrol(A,k,n);           
 Umn=new float [n];           
 func(A,b,Umn,n,k);               
 vyvod(Umn,n);                    
 getch();
 delete [] A;
 delete [] b;                      
 delete [] Umn;
 return 0;
}
//---------------------------------------------------------------------------
void vvodM(float*C,int k, int n)
{int i=0,j=0,l=0;
 
for(i=0;i<k;i++)
{
printf("\n An [%d][%d]=",j,l);l++; //ввод матрицы
if(l==n) {l=0;j++;l=j;}
C[i]=zachita();
//scanf("%f",&C[i]);
 
}
}
 
void vvod(float*C,int n)
{int i=0;
for(i=0;i<n;i++)
{
printf("\n b [%d]=",i);//ввод вектора
C[i]=zachita();
//scanf("%f",&C[i]);
}
}
 
void func(float *A, float *b, float *C, int n, int k)  // решение
{int i=0,j=0,l=0,n1=0;
 float sum=0;
 for(l=0;l<n;l++)
 {
 
     for (j=l;j<n;j++)          
        {sum += A[i++]*b[j];    
        }
     C[l]=sum;sum=0;
 }
}
 
void vyvod(float *C, int n) // вывод вектора Аb
{int i=0;
 printf(r("\n\nВектор Ab:\n"));
 for(i=0;i<n;i++)
 {printf("\n Ab[%d]=%f",i,C[i]);     
   }
}
 
void kontrol(float *C, int k, int n) // вывод матрицы
{int i=0,j=0,l=0;
printf(r("\nВы ввели матрицуу:\n"));
 do{
     for (i=0;i<n;i++)
       {printf("\n");
        for (j=0;j<n;j++)
            {if(j>=i) {printf("\t%0.3f",C[l]);l++;}
             else {printf("\t %d",0);}}
      }
   }while(l!=k);
}
 
float zachita()   // защита
 {
 float q;
 char x,a[6];
 for(int j=0;j<6;j++)
 {a[j]=NULL;}
 int i=0,k=0,g=0,t=0;
  do{x=getch();
  //printf("%d",&x);
   if(x>=48 && x<=57 && i<(t+3))
    {printf("%c",x);
    a[i]=x;
    i++;}
//----------------------------
    if(i!=0){if(x==8)
    {printf("%c %c",8, 8);
    i--;if(g==i){k=0;g=0;}
    a[i]=0;
    }}
//----------------------------
   if(x==45 && i==0)
    {printf("%c",x);
    a[i]=x;
    i++;g++;t=g;}
//-------------------------------
    if(k==0)
    {if(x==46)
    {printf("%c",x);
    a[i]=x;g=i;t=(g+1);
    i++;
    k=1;}}
 
   }while(x!=13);
   q=atof(a);
    return q;
}
 
  int zachita_int()
 {int q;
 char x,a[3];
 int i=0;
  do{x=getch();
   if(x>=48 && x<=57 && i<4 )
   {printf("%c",x);
    a[i]=x;
    i++;}
    if(i!=0){if(x==8)
    {printf("%c %c",8, 8);
    i--;
    a[i]=0;} }
   }while(x!=13);
   q=atof(a);
  return q;
  }
Добавлено через 1 час 41 минуту 46 секунд
смысл такой , допустим вводм симметричную
матрицу А и вектор b
1 2 3 4
2 4 5 5
3 5 6

Добавлено через 3 минуты 23 секунды
Как записать Симметричную квадратную матрицу???

Добавлено через 3 часа 46 минут 16 секунд
Up
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
23.06.2009, 20:52
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Симметричная квадратная матрица (C++):

Квадратная матрица и симметричная её часть - C++
Помогите решить задачу, пожалуйста: Написать функцию,которая вычисляет для заданной квадратной матрицы А симметричную её часть S(ij) =...

Квадратная матрица, симметричная относительно главной диагонали, задана верхним треугольником в виде одномерного массива.Восстановить исходную матрицу - C++
Квадратная матрица, симметричная относительно главной диагонали, задана верхним треугольником в виде одномерного массива. Восстановить...

дана квадратичная матрица z[n][n]. составить программу, которая если матрица симметричная(транспонированная матрица равна исходной), сделает ее не сим - C++
помогите пожалуйста. условие: дана квадратичная матрица z. составить программу, которая если матрица симметричная(транспонированная...

Симметричная матрица - C++
Заполнить матрицу случайными числами. Отобразить матрицу симметрично относительно главной диагонали. Тоесть должна вийти матрица вида: ...

реализация класса "симметричная матрица целых чисел"... - C++
Условие вообще такое: Определите пользовательский тип “симметричная матрица целых чисел” для обработки квадратных матриц, в которых A...

Квадратная матрица - C++
Сформировать квадратную матрицу порядка n (n - четное), где на главной диагонали элементы от n до 1, а остальные элементы нули.

4
Виталий Vi
3 / 3 / 0
Регистрация: 22.06.2009
Сообщений: 6
23.06.2009, 20:53 #2
может у кого - нибудь есть задача на квадратную симметричную матрицу???
а то задание интересное...
0
Jiton
2 / 2 / 1
Регистрация: 09.12.2008
Сообщений: 14
23.06.2009, 23:19  [ТС] #3
неужели задача такая сложная?
помогите

Добавлено через 1 час 20 минут 33 секунды
есть вот такая задача алгоритм приведен
матрица А
1 2 3
0 4 5
0 0 6
и вектор b (7 8 10)мы их перемножаем
а мне нужно сделать немного другую задачу, ввести симметричную матрицу А
1 2 3
2 4 5
3 5 6
и вектор b(7 3 5), и перемножить их и найти длину вектора Аb (числа я просто взял для наглядности чтобы было понятно, а так матрица должна быть квадратной и симметричной)
0
accept
4823 / 3244 / 165
Регистрация: 10.12.2008
Сообщений: 10,682
24.06.2009, 04:58 #4
симметричная матрица - это когда Aij = Aji
0
Jiton
2 / 2 / 1
Регистрация: 09.12.2008
Сообщений: 14
24.06.2009, 11:51  [ТС] #5
все уже, зашел в раздел платные услуги и там сделали
0
24.06.2009, 11:51
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
24.06.2009, 11:51
Привет! Вот еще темы с ответами:

Квадратная матрица ! - C++
Дана квадратная матрица размерности n × n . Найти максимальный элемент каждой строки и поменять его с элементом этой строки, стоящим в ...

квадратная матрица - C++
Дана целочисленная квадратная матрица. Определить максимум среди сумм элементов диагоналей, параллельных главной диагонали матрицы.

Квадратная матрица - C++
Сегодня зачет, а я не могу написать следующую программу: Дана целочисленная квадратная матрица. Определить произведение элементов в тех...

Квадратная матрица - C++
Ребят, помогите пожалуйста, нужно решить вот такую задачку: Дана действительная квадратная матрица порядка n. Выяснить, верно ли что...


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

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

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