@timur102

Почему программа работает некорректно?

Есть программа, которая что-то высчитывает:
#include <stdio.h>

int count_of_combinations(int k, int n);
int factorial (int n);

int main(){
	int n = 0,k = 0, count;
	int sub_factorial[10] = {0, 0, 1, 2, 9, 44, 265, 1854, 14833, 133496};
	scanf("%d%d", &n, &k);
	int combinations = sub_factorial[n-k];
        int q = factorial(n);
        int q1 = factorial(n-k);
        int q2 = factorial(k);
	count = count_of_combinations(n,k);
	printf("%d\n", count*combinations);


	return 0;

}

int count_of_combinations(int n, int k){
	return factorial(n) / (factorial(k) * factorial(n-k));
}


int factorial (int n)
{
  return (n < 2) ? 1 : n * factorial (n - 1);
}


И вся проблема в том, что переменная q2 принимает значение рандомное значение при k = 1
А после исполнения q2 = 1 (так должно быть)
Вот что говорит gdb:
Reading symbols from ./prog...done.
(gdb) b 13
Breakpoint 1 at 0x1214: file prog.c, line 13.
(gdb) b 17
Breakpoint 2 at 0x124d: file prog.c, line 18.
(gdb) r
Starting program: ./prog
9 1

Breakpoint 1, main () at prog.c:13
13		int q2 = factorial(k);
(gdb) p q2
$1 = 1431655213
(gdb) p k
$2 = 1
(gdb) c
Continuing.
133497

Breakpoint 2, main () at prog.c:18
18		return 0;
(gdb) p k
$3 = 1
(gdb) p q2
$4 = 1


Почему? В чем ошибка?
  • Вопрос задан
  • 96 просмотров
Решения вопроса 1
@dedalqq
Мня смущает вот это: scanf("%d%d", &n, &k);
Подозреваю, что какие то неоднозначное поведение. попробуйте заменить это на
scanf("%d", &k);
scanf("%d", &n);
P. S.
и вообще, по моему проще это получать из параметров =)
Ответ написан
Комментировать
Пригласить эксперта
Ваш ответ на вопрос

Войдите, чтобы написать ответ

Войти через центр авторизации
Похожие вопросы