Malek Dance Club(遞推)

Malek Dance Club
time limit per test
1 second
memory limit per test
256 megabytes
input
standard input
output
standard output

As a tradition, every year before IOI all the members of Natalia Fan Club are invited to Malek Dance Club to have a fun night together. Malek Dance Club has 2n members and coincidentally Natalia Fan Club also has 2nmembers. Each member of MDC is assigned a unique id i from 0 to 2n - 1. The same holds for each member of NFC.ios

One of the parts of this tradition is one by one dance, where each member of MDC dances with a member of NFC. A dance pair is a pair of numbers (a, b) such that member a from MDC dances with member b from NFC.app

The complexity of a pairs' assignment is the number of pairs of dancing pairs (a, b) and (c, d) such that a < c andb > d.ide

You are given a binary number of length n named x. We know that member i from MDC dances with member  from NFC. Your task is to calculate the complexity of this assignment modulo 1000000007 (109 + 7).this

Expression  denotes applying «XOR» to numbers x and y. This operation exists in all modern programming languages, for example, in C++ and Java it denotes as «^», in Pascal — «xor».spa

注意到n很小,若是可以求出遞推公式,問題將很容易獲得解決。code

x長度爲n,f(x)表示complexity,顯然f(0)=0,f(1)=1。當n>1時,f(0x)和f(1x)可由f(x)推出。orm

(1)求f(0x): i 分別取 0,1,...,2^n-1,j分別取2^n,...,2^(n+1) - 1, 統計(i,i  xor 0x)與(j, j xor 0x)能組成多少對,注意j xor 0x的第一位是1,而i xor 0x的第一位是0,故而 j xor 0x > i  xor 0x,而 j > i,故(i,i  xor 0x)與(j, j xor 0x)不能配對。統計(j, j xor 0x)內部能組成多少對,全部j的第一位相同, 致使j xor 0x的第一位都相同,故而j的第一位是沒有比較意義的,去掉沒有影響,故(j, j xor 0x)的配對數爲f(x)。因此f(0x)=2f(x)blog

(2)求f(1x):  i 分別取 0,1,...,2^n-1,j分別取2^n,...,2^(n+1) - 1, 統計(i,i  xor 1x)與(j, j xor 1x)能組成多少對,注意j xor 1x的第一位是0,而i xor 1x的第一位是1,故而 i  xor 1x > j xor 1x ,而 i < j,故(i,i  xor 1x)與(j, j xor 1x)之間能產生2^(2n)對。統計(j, j xor 0x)內部能組成多少對,全部j的第一位都相同, 致使j xor 1x的第一位都相同,故而j的第一位是沒有比較意義的,去掉沒有影響,故(j, j xor 0x)的配對數爲f(x)。因此f(1x)=2f(x)+2^(2n)ci

綜上:get

  • f(0x) = 2f(x)
  • f(1x) = 2f(x) + 2^2n
 1 #include <iostream>
 2 #include <string>
 3 #include <algorithm>
 4 #include <map>
 5 #include <vector>
 6 #include <cstdio>
 7 #include <cmath>
 8 #include <cstring>
 9 using namespace std;
10 
11 char x[101];
12 const int m = 1000000007;
13 int n;
14 
15 long long POW(long long a, long long b)
16 {
17     if(!b) return 1;
18     long long c = POW(a, b>>1);
19     c = (c * c) % m;
20     if(b & 1)
21     {
22         c = (c * a) % m;
23     }
24     return c;
25 }
26 
27 int f(int k)
28 {
29     if(k == n - 1)
30     {
31         if(x[k] == '0') return 0;
32         else return 1;
33     }
34     if(x[k] == '0') return (2 * f(k + 1)) % m;
35     else return ((2 * f(k + 1)) % m + POW(4, n - k - 1)) % m;
36 }
37 
38 int main()
39 {
40     while(scanf("%s", x) != EOF)
41     {
42         n = strlen(x);
43         printf("%d\n", f(0));
44     }
45     return 0;
46 }
相關文章
相關標籤/搜索