Форум программистов, компьютерный форум, киберфорум
PascalABC.NET
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.82/11: Рейтинг темы: голосов - 11, средняя оценка - 4.82
0 / 0 / 0
Регистрация: 26.11.2019
Сообщений: 15

Написать функцию для вычисления биноминальных коэффициентов

21.05.2020, 17:42. Показов 1990. Ответов 6

Студворк — интернет-сервис помощи студентам
Написать функцию C(M,N), где 0<=M<=N, для вычисления
биноминальных коэффициентов: C(M,N)=N!/(M!*(N-M)!)

Пытался сделать сам, ничего не получается, происходит переполнение стека.
0
cpp_developer
Эксперт
20123 / 5690 / 1417
Регистрация: 09.04.2010
Сообщений: 22,546
Блог
21.05.2020, 17:42
Ответы с готовыми решениями:

Написать процедуру для вычисления коэффициентов и функцию для вычисления значения многочлена
Задано многочлен {P}_{n}(x) степени n&lt;=100, коэффициенты которого содержатся в действительном массиве A(n+1), и действительные числа...

Написать программу, которая выводит значения факториалов чисел от 0 до N. Для вычисления факториала числа написать функцию пользователя
Написать программу, которая выводит значения факториалов чисел от 0 до N. Для вычисления факториала числа написать функцию пользователя.

Написать функцию для вычисления n!
3. Написать функцию для вычисления n!=1•2•3•...•n. Вычислить факториалы чисел от 1 до 7. Срочно ребят.

6
Эксперт Pascal/Delphi
6812 / 4568 / 4820
Регистрация: 05.06.2014
Сообщений: 22,434
21.05.2020, 17:47
Цитата Сообщение от NikitaG_1 Посмотреть сообщение
Пытался сделать сам
Покажите, что попытались.
0
0 / 0 / 0
Регистрация: 26.11.2019
Сообщений: 15
21.05.2020, 18:15  [ТС]
На комментарии не обращайте внимания, не успел переписать под эту программу.

Pascal
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
program lab9;
 
uses crt;
 
procedure Input(var x1: integer; x2: integer);// ввод двух чисел
var
  code: integer;
  str: string;
begin
repeat
  repeat
   writeln('Enter the number M: ');
    readln(str);
    val(str, x1, code);
    if code <> 0 then write('Error... ');
  until code = 0;
  repeat
    writeln('Enter the number N: ');
    readln(str);
    val(str, x2, code);
    if code <> 0 then write('Error... ');
  until code = 0;
  if (x1<=0) and (x2<=x1) then write ('Error... n>=m>=0');
until(x1>=0)and(x2>=x1);
end;
 
function fact(x: integer): integer;
begin
  if x = 1 then fact := 1
  else fact := fact(x - 1) * x;
end;
 
function C(var m, n: integer): real;
begin
   C := fact(N) / (fact(M) * fact(N - M));
end;
 
 
 
//основная программа
var
  numM: integer;
  numN: integer;
  comb:real;
  key: char;//символ из буфера клавиатуры
 
label continue, enter, error;
 
begin
  Clrscr; //очистка экрана ввода/вывода
  Writeln('This program is designed to calculate the fractional part of the arithmetic mean of two given values positive real numbers');
  Input(numN, numM);
  Writeln('Press the spacebar to re-enter the data, "Enter" to continue working or "Esc" to exit the program.');
  
  repeat
    key := readkey; //считывание символа из буфера клавиатуры
    
    if key = #27 then halt //выход из программы нажатием клавиши Esc
    else
    if key = #32 then Input(numM, numN) //повторный ввод данных нажатием клавиши пробел
    else
    
    if key = #13 then C(numM, numN) //продолжение программы на процедуру вычисления дробной части среднего арифметического двух полождительных вещественных чисел.
    else
      writeln('Error'); //сообщение об ошибке
  until (key = #27) or (key = #13) or (key = #32);
  comb:=C(NumM,NumN);
  write('Число сочетаний=', comb:0:0);
  readln
end.
0
Эксперт Pascal/Delphi
6812 / 4568 / 4820
Регистрация: 05.06.2014
Сообщений: 22,434
21.05.2020, 18:24
У вас рекурсивная функция факториала падает с переполнением.
Попробуйте вот эту:
Pascal
1
2
3
4
5
6
7
8
function fact(j: Integer): Integer;
var
  i, f: Integer;
begin
  f := 1;
  for i := 2 to j do f := f * i;
  fact := f
end;
1
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
21.05.2020, 19:07
Лучший ответ Сообщение было отмечено ZX Spectrum-128 как решение

Решение

Здесь факториал не нужен.
Pascal
1
2
3
4
5
6
function C(n,m:integer):integer;
begin
if ((m=0)and(n>0))or(m=n) then C:=1 else
if(n>0)and(n<m) then C:=0
else C:=C(n-1,m-1)+C(n-1,m);
end;
2
0 / 0 / 0
Регистрация: 26.11.2019
Сообщений: 15
26.05.2020, 14:52  [ТС]
Отдельно от процедур ввода и вывода работает, с процедурами не хочет. Не выводит с помощью Output значение
Помогите, пожалуйста, разобраться
Pascal
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
program test;
uses crt;
procedure Input(var x1,x2: integer);// ввод двух чисел
var
  code: integer;
  str: string;
begin
repeat
  repeat
   writeln('Enter the number M: ');
    readln(str);
    val(str, x1, code);
    if code <> 0 then write('Error... ');
  until code = 0;
  repeat
    writeln('Enter the number N: ');
    readln(str);
    val(str, x2, code);
    if code <> 0 then write('Error... ');
  until code = 0;
  if (x1<=0) and (x2<=x1) then write ('Error... n>=m>=0');
until(x1>=0)and(x2>=x1);
end;
 
function C(n,m:integer):integer;
begin
if ((m=0)and(n>0))or(m=n) then C:=1 else
if(n>0)and(n<m) then C:=0
else C:=C(n-1,m-1)+C(n-1,m);
end;
 
procedure Output (var C:integer);
begin 
  writeln('Число сочетаний = ', C);
end;
 
//основная программа
var
  numM: integer;
  numN: integer;
  comb:integer;
  key: char;//символ из буфера клавиатуры
 
label continue, enter, error;
 
begin
  Clrscr; //очистка экрана ввода/вывода
  Writeln('This program is designed to calculate the fractional part of the arithmetic mean of two given values positive real numbers');
  Input(numN, numM);
  Writeln('Press the spacebar to re-enter the data, "Enter" to continue working or "Esc" to exit the program.');
  
  repeat
    key := readkey; //считывание символа из буфера клавиатуры
    
    if key = #27 then halt //выход из программы нажатием клавиши Esc
    else
    if key = #32 then Input(numM, numN) //повторный ввод данных нажатием клавиши пробел
    else
    
    if key = #13 then C(numM, numN) //продолжение программы на процедуру вычисления дробной части среднего арифметического двух полождительных вещественных чисел.
    else
      writeln('Error'); //сообщение об ошибке
  until (key = #27) or (key = #13) or (key = #32);
  Output(comb);
  readln
end.
0
Почетный модератор
 Аватар для Puporev
64315 / 47611 / 32743
Регистрация: 18.05.2008
Сообщений: 115,167
26.05.2020, 15:54
Лучший ответ Сообщение было отмечено NikitaG_1 как решение

Решение

Всякие хотелки выкинул , остальное поправил
Pascal
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
procedure Input(var x1,x2: integer);// ввод двух чисел
var
  code: integer;
  str: string;
begin
repeat
  repeat
   writeln('Enter the number M: ');
    readln(str);
    val(str, x1, code);
    if code <> 0 then write('Error... ');
  until code = 0;
  repeat
    writeln('Enter the number N: '); //x2<=x1
    readln(str);
    val(str, x2, code);
    if code <> 0 then write('Error... ');
  until code = 0;
  if (x2<=0) and (x1<=x2) then write ('Error... n>=m>=0');
until(x2>=0)and(x1>=x2);
end;
 
function C(n,m:integer):integer;
begin
if ((m=0)and(n>0))or(m=n) then C:=1 else
if(n>0)and(n<m) then C:=0
else C:=C(n-1,m-1)+C(n-1,m);
end;
 
procedure Output(x1,x2:integer);
begin
  writeln('Число сочетаний = ', C(x1,x2));
end;
 
//основная программа
var
 x1,x2:integer;
begin
  Clrscr; //очистка экрана ввода/вывода
  Writeln('This program is designed to calculate the fractional part of the arithmetic mean of two given values positive real numbers');
  Input(x1,x2);
  writeln('x1=',x1,' x2=',x2);
  Output(x1,x2);
  readln
end.
1
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
raxper
Эксперт
30234 / 6612 / 1498
Регистрация: 28.12.2010
Сообщений: 21,154
Блог
26.05.2020, 15:54
Помогаю со студенческими работами здесь

Написать функцию для вычисления тангенса
добрый вечер Написать функцию для вычисления тангенса. найти tg(0,9), tg(0,1), tg(-0,9), воспользовавшись формулой Y=sin(x)/cos(x) ...

Написать функцию для вычисления тангенса
Написать функцию для вычисления тангенса. Найти ctg(0,9), ctg(0,1), ctg(-0,9), используя формулу Y=cos(x)/sin(x).

Написать функцию для вычисления выражения
Написать функцию для вычисления выражения (см.вложения) , a.

Написать рекурсивную функцию для вычисления x^n
Написать рекурсивную функцию для вычисления x^n, число x и показатель степени вводятся с клавиатуры, n- натуральное число.

Написать функцию и программу для ее проверки для вычисления функции sin(x) C++
Написать функцию и программу для ее проверки для вычисления функции sin(x).


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

Или воспользуйтесь поиском по форуму:
7
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
SDL3 для Web (WebAssembly): Подключение Box2D v3, физика и отрисовка коллайдеров
8Observer8 12.02.2026
Содержание блога Box2D - это библиотека для 2D физики для анимаций и игр. С её помощью можно определять были ли коллизии между конкретными объектами и вызывать обработчики событий столкновения. . . .
SDL3 для Web (WebAssembly): Загрузка PNG с прозрачным фоном с помощью SDL_LoadPNG (без SDL3_image)
8Observer8 11.02.2026
Содержание блога Библиотека SDL3 содержит встроенные инструменты для базовой работы с изображениями - без использования библиотеки SDL3_image. Пошагово создадим проект для загрузки изображения. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru