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

Реализовать решения задачи в виде функций (исправить) - C++

Восстановить пароль Регистрация
 
Nuki
0 / 0 / 0
Регистрация: 13.04.2013
Сообщений: 13
08.12.2013, 12:14     Реализовать решения задачи в виде функций (исправить) #1
помогите исправить...

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 <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;
}
Вложения
Тип файла: txt Новый текстовый документ.txt (4.0 Кб, 6 просмотров)
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
08.12.2013, 12:14     Реализовать решения задачи в виде функций (исправить)
Посмотрите здесь:

Составить программу решения поставленной задачи: Вычислить m значений функции f(x) на отрезке [a, b]. Вычисление величины f(x) оформить в виде функц C++
Реализовать статическое и динамическое решение, оформив основные этапы решения задачи в виде функций. C++
C++ Алгоритм решения рекурсивных функций
Составить программу решения поставленной задачи: Вычислить m значений функции f(x) на отрезке [a, b]. Вычисление величины f(x) оформить в виде функц C++
C++ Составить алгоритм решения задачи в виде блок-схемы
C++ Составить алгоритм решения в виде блок-схемы
Оформить простейшие задачи в виде функций C++
Реализовать все алгоритмы сортировки, оформив решение в виде функций ввода, вывода и обработки массивов C++

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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
Ответ Создать тему
Опции темы

Текущее время: 14:22. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru