AtCoder Regular Contest 058

C - こだわり者いろはちゃん / Iroha's Obsession

暴力。

#include<cstdio>
#include<iostream>
using namespace std;
int n, k;
bool a[10];
bool check(int x) {
    for (; x; x /= 10)
        if (a[x%10]) return false;
    return true;
}
int main() {
    scanf("%d%d", &n, &k);
    for (int i = 0, t; i < k; ++i)
        scanf("%d", &t), a[t] = 1;
    while (!check(n)) ++n;
    printf("%d\n", n);
    return 0;
}

D - いろはちゃんとマス目 / Iroha and a Grid

把路分成两条,分别算出方案数,然后再乘起来就行。

#include<cstdio>
#include<iostream>
using namespace std;
typedef long long ll;
const ll mod = 1e9 + 7;
ll pow(ll a, ll b, ll m) {
    ll res = 1;
    for (a %= m; b; b >>= 1, (a *= a) %= m)
        if (b & 1) (res *= a) %= m;
    return res;
}
ll n, m, a, b, ans, f[200005];
ll inv(ll x) {
    return pow(x, mod - 2, mod);
}
ll C(ll n, ll k) {
    return f[n] * inv(f[n-k]) % mod * inv(f[k]) % mod;
}
ll calc(ll n, ll m) {
    return C(n + m, m);
}
int main() {
    cin >> n >> m >> a >> b; f[0] = 1;
    for (ll i = 1; i <= n + m - 2; ++i)
        f[i] = f[i-1] * i % mod;
    for (ll i = b + 1; i <= m; ++i) {
        (ans += calc(n - a - 1, i - 1) % mod * calc(a - 1, m - i)) %= mod;
    }
    ans = (ans % mod + mod) % mod;
    cout << ans << endl;
    return 0;
}

 

posted @ 2017-12-20 11:52  p0ny  阅读(276)  评论(0编辑  收藏  举报