Вот и я думаю, что что-то не так сделал.
Не подскажите, как именно нужно это исправить?
Добавлено через 25 минут
Действительно, что-то тупанул, начав вводить i снова, исправил. А как исправить, чтобы не делилось целое на целое? Вроде int на float или double менял не помогло.
Добавлено через 11 минут
Так и это вроде исправил. Теперь код выглядит так:
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
| #include "stdafx.h"
#include "locale.h"
#include "conio.h"
#include "math.h"
#include <iostream>
using namespace std;
double algP(float N, float& x);
double stepen(float& i, float& x);
double algS(float N, float S, float& x, float& i);
int main(double *P)
{setlocale (LC_ALL, "RUS");
float N=0, S=0, i=0;
float x;
cout << "Введите N: ";
cin >> N;
cout << "\nВведите x: " ;
cin >> x;
cout << algP(N, x) << endl;
cout << "\nПроизведение: " << P;
cout << algS(N,S,x,i) << endl;
getch();
return 0;
}
double algP(float N, float& x)
{
double P=1;
float i=N;
P=x-i;
if (N==1) return P;
else return P*algP(N-1,x);
}
double stepen(float& i, float& x)
{
float rezult=1;
for(int k=0; k<i; k++)
rezult *=x;
cout<< endl<< "Результата возведения в степень "<<i<< " числа "<< x << " = "<<rezult;
return 1;
}
double algS(float N, float S, float& x, float& i)
{
i=N;
for (int k=0; k<=N; k++)
{
S+=(1/stepen( i, x));
}
cout << "\nСумма: " << S;
if (N==1) return S;
else return algS(N-1,S-1,x,i);
} |
|
Вот только все равно как-то нехорошо ответы выдает. Правильно ли я вообще записал условия задачи?