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

Определить количество раскрасок полоски из N клеток - C++

Восстановить пароль Регистрация
 
Brat_OK
0 / 0 / 0
Регистрация: 01.09.2013
Сообщений: 20
02.04.2014, 18:58     Определить количество раскрасок полоски из N клеток #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
#include <iostream>
#include <cstdio>
#include <cassert>
#include <cmath>
 
using namespace std;
 
const int MOD = 1e9+7;
 
int fact(int n)
{
    if (n==0)
        return 1;
    if (n<0)
        return 0;
 
    long long f = 1;
 
    for(int i=2;i<=n;i++)
        f = (f*i)%MOD;
 
    return f;
}
 
long long CNK (int n, int k)
{
    return fact(n)/(fact(n-k)*fact(k));
}
 
long long ANK (int n, int k)
{
    return fact(n)/ (fact(n-k));
}
 
int main()
{
  int n,a,b,c,sum, ans, k=0;
 
  cin >> n >> a >> b >> c;
 
  sum = a+b+c;
 
  if (sum > n)
        {
            cout << 0;
            return 0;
        }
 
    if (a > 0)
        k++;
    if (b > 0)
        k++;
    if (c > 0)
        k++;
 
   ans = CNK(n,sum) * pow(3,n-sum) * fact(k);
 
   cout << ans;
 
}
Если нужно, могу объяснить идею моего решения.
Миниатюры
Определить количество раскрасок полоски из N клеток  
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
02.04.2014, 18:58     Определить количество раскрасок полоски из N клеток
Посмотрите здесь:

Посчитать количество пустых клеток шахматной доски, которые не бьются ни одним ферзем C++
C++ из листа клетчатой бумаги N*N клеток вырезали М клеток . на сколько кусков распадается оставшаяся часть листа?
C++ Определить количество выигрышей, количество проигрышей и количество ничьих данной команды
В массиве записаны результаты N игр футбольной команды. Определить количество выигрышей, количество проигрышей и количество ничьих данной команды. C++
C++ Определить, сколько существует различных раскрасок полоски из N клеток
Определить количество слов в заданном тексте и количество символов в каждом слове C++
Определить количество лет, в которые количество осадков превышало среднегодовое C++
Пользователь вводит строку. Определить количество букв (рус eng), количество цифр и количество остальных C++

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

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

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