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 <string.h>
main()
{
struct NOTE{char NAME[20],TELE[15];unsigned BDAY[3];}BNOTE[8],T;
int i,j,k=0; char Number[15];
for(i=0;i<8;i++)
{
printf("\nName? "); gets(BNOTE[i].NAME);
if(strlen(BNOTE[i].NAME)==0)break;
printf("Phone number? "); gets(BNOTE[i].TELE);
printf("Birthday (YYYY MM DD)? ");
for(j=0;j<3;j++)scanf("%u",&BNOTE[i].BDAY[j]);
gets(Number); k++;
};
for(i=0;i<k;i++)for(j=0;j<k-i-1;j++)
if((long)1000*BNOTE[j].BDAY[0]+50*BNOTE[j].BDAY[1]+BNOTE[j].BDAY[2]>
(long)1000*BNOTE[j+1].BDAY[0]+50*BNOTE[j+1].BDAY[1]+BNOTE[j+1].BDAY[2])
{T=BNOTE[j];BNOTE[j]=BNOTE[j+1];BNOTE[j+1]=T;}
printf("\nNumber for the seach? "); gets(Number); j=0;
for(i=0;i<k;i++)if(!strcmp(Number,BNOTE[i].TELE))
{
printf("\nName: %s \nPhone number: %s \nBirthday: %u %u %u\n\n",
BNOTE[i].NAME, BNOTE[i].TELE,
BNOTE[i].BDAY[0],BNOTE[i].BDAY[1],BNOTE[i].BDAY[2]);j=1;
};
if(!j)printf("No such person!\n\n");
getch();
}
Можете еще вот это исправить.. чтобы матрица выводилась на экран
#include <iostream>
#include <stdlib.h>
using namespace std;
//------------------------------------------------------------------
//Функция, которая вычеркивает определенную строку и столбец
//вызывается из функции Determinant
void GetMatrix(double **M,double **B,const int &N,const int &Y,const int &X){
int dy = 0, dx;
for(int ky=0;ky<N-1;ky++){
if(ky == Y) dy = 1;
dx = 0;
for(int kx=0;kx<N-1;kx++){
if(kx == X) dx = 1;
B[ky][kx] = M[ky+dy][kx+dx];
}
}
}
//------------------------------------------------------------------
//Функция рекурсивно вычисляющая определитель
double Determinant(double **M,const int &N){
double **B = new double *[N];
for(int i=0;i<N;i++)
B[i] = new double [N];
//-----------------------------
double det = 0.0, k = 1.0;
//-----------------------------
if(N == 1) det = M[0][0];
else
if(N == 2) det = M[0][0]*M[1][1] - M[1][0]*M[0][1];
else
for(int y=0;y<N;y++){
GetMatrix(M,B,N,y,0);
det += k*M[y][0]*Determinant(B,N-1);
k = -k;
}
//-----------------------------
if(B){
for(int i=0;i<N;i++){
delete [] B[i];
B[i] = NULL;
}
delete [] B;
B = NULL;
}
//-----------------------------
return det;
}
//------------------------------------------------------------------
//Функция вычисляющая произведение элементов под главной диагональю
double MultSubDiag(double **M,const int &N){
double mult = 1.0;
for(int y=1;y<N;y++)
for(int x=0;x<y;x++)
mult *= M[y][x];
return mult;
}
//------------------------------------------------------------------
//Функция возвращающая минимальный элемент главной диагонали
double MinDiagElement(double **M,const int &N){
double minimum = M[0][0];
for(int i=0;i<N;i++)
minimum = (minimum < M[i][i]) ? minimum : M[i][i];
return minimum;
}
//------------------------------------------------------------------
int main(int argc, char *argv[]) {
int N;
double **M;
cout << "Enter matrix size. N = ";
cin >> N;
//выделение памяти под матрицу
M = new double *[N];
for(int i=0;i<N;i++)
M[i] = new double [N];
//заполнение матрицы элементами
cout << "Enter elements of matrix M[y][x]" << endl;
for(int y=0;y<N;y++)
for(int x=0;x<N;x++){
cout << "M[" << y << "][" << x << "] = ";
cin >> M[y][x];
}
cout << endl;
//вывод минимального диагонального элемента
cout << "Minimal diagonal element is " << MinDiagElement(M,N) << endl;
cout << endl;
//вывод произведения элементов ниже главной диагонали
cout << "Production of subdiagonal element is " << MultSubDiag(M,N) << endl;
cout << endl;
//вывод детерминанта
cout << "Determinant of the matrix is " << Determinant(M,N) << endl;
cout << endl;
//освобождение памяти
if(M){
for(int i=0;i<N;i++){
delete [] M[i];
M[i] = NULL;
}
delete [] M;
M = NULL;
}
system("pause");
return 0;
} |