Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Карта форума Темы раздела Блоги Сообщество Поиск Заказать работу  
 
0 / 0 / 0
Регистрация: 13.04.2013
Сообщений: 13
1

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

08.12.2013, 12:14. Показов 648. Ответов 0
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
помогите исправить...

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 Кб, 9 просмотров)
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
08.12.2013, 12:14
Ответы с готовыми решениями:

Реализовать статическое и динамическое решение, оформив основные этапы решения задачи в виде функций.
Помогите плиииииииз(( Реализовать статическое и динамическое решение, оформив основные...

Нужно разработать алгоритм решения этой задачи и изобразить его в виде блок -схемы и в виде структурированного текста (псевдокода).
Даны натуральное число m , одноименный действительный массив В порядка m. Переписать массив В в...

Реализовать решения функций на заданном интервале
Даны две функции обе на интервале 1) 1/x^2 при x&gt;0 x^2 при x&lt;=0 2) -1 при...

Составить алгоритм решения задачи в виде программы
Помогите) желательно с подробностями. y=\sum_{k=1}^{20}k^3\left(\sum_{n=1}^{15}(k-n)^2 \right)

0
08.12.2013, 12:14
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
08.12.2013, 12:14
Помогаю со студенческими работами здесь

Реализовать циклический алгоритм решения задачи
Создать программу , реализующую циклический алгоритм решения задачи индивидуального варианта.

Реализовать алгоритм решения задачи коммивояжера
дали задание: Реализовать алгоритм решения задачи коммивояжера. честно говоря, даже не знаю с...

Составить алгоритм решения задачи в виде блок-схемы
Последовательно вводятся N целых чисел.Определить,сколько из них совпадают с первым числом. Нужно...

Оформить простейшие задачи в виде функций
Ребят помогите пожалуйста с задачками для CodeBlocks. Реализовать задачи 1 и 2 в виде функций...

Реализовать вычисление в виде функций
Есть задание - Значение аргумента x изменяется от a до b с шагом h. Для каждого x найти значения...

Реализовать алгоритм решения задачи «Ханойские башни»
задание: Реализовать алгоритм для решения задачи «Ханойские башни». Выписать последовательность...


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

Или воспользуйтесь поиском по форуму:
1
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru