Submission #1195822


Source Code Expand

#include<iostream>
#include<algorithm>
#include<vector>

using namespace std;
typedef long long Int;

Int n;
Int pp = 1;
Int dp[210][210];

vector<Int> go(){
  vector<Int> res;
  Int k = 0;
  while((1LL << k) - 1 <= n)k++;
  Int p = 1;
  for(Int i = 0;i < k;i++)res.push_back(pp);pp++;
  n -= (1LL << (k-1)) - 1;
  for(Int i = k/2;i >= 0;i--){
    Int tmp = 0;
    for(Int j = 0;j <= k;j++){
      tmp += dp[i][j] * dp[k - i][j];
      if(tmp > n)break;
    }
    if(tmp > n)continue;;
    n -= tmp;
    res.insert(res.begin() + (p - 1), pp);
    res.insert(res.begin() + (i + p), pp);
    p++;
    pp++;
  }

  return res;
}

int main(){
  cin >> n;
  for(Int i = 0;i < 200;i++){
    for(Int j = 0;j < 200;j++){
      if(i < j)dp[i][j] = 0;
      else if(j == 0 || i == j)dp[i][j] = 1;
      else dp[i][j] = dp[i-1][j] + dp[i-1][j-1];
    }
  }

  vector<Int> res;
  
  while(n){
    vector<Int> tmp = go();
    res.insert(res.end(), tmp.begin(), tmp.end());
  }

  cout << res.size() << endl;
  for(Int i = 0;i < res.size();i++)cout << res[i] << " ";
  cout << endl;
  return 0;
}

Submission Info

Submission Time
Task C - Tautonym Puzzle
User catupper
Language C++14 (GCC 5.4.1)
Score 1000
Code Size 1138 Byte
Status AC
Exec Time 1 ms
Memory 640 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 1000 / 1000
Status
AC × 2
AC × 32
Set Name Test Cases
Sample 00_example_01.txt, 00_example_02.txt
All 00_example_01.txt, 00_example_02.txt, 01.txt, 02.txt, 03.txt, 04.txt, 05.txt, 06.txt, 07.txt, 08.txt, 09.txt, 10.txt, 11.txt, 12.txt, 13.txt, 14.txt, 15.txt, 16.txt, 17.txt, 18.txt, 19.txt, 20.txt, 21.txt, 22.txt, 23.txt, 24.txt, 25.txt, 26.txt, 27.txt, 28.txt, 29.txt, 30.txt
Case Name Status Exec Time Memory
00_example_01.txt AC 1 ms 512 KB
00_example_02.txt AC 1 ms 640 KB
01.txt AC 1 ms 640 KB
02.txt AC 1 ms 640 KB
03.txt AC 1 ms 640 KB
04.txt AC 1 ms 640 KB
05.txt AC 1 ms 512 KB
06.txt AC 1 ms 512 KB
07.txt AC 1 ms 640 KB
08.txt AC 1 ms 640 KB
09.txt AC 1 ms 512 KB
10.txt AC 1 ms 640 KB
11.txt AC 1 ms 640 KB
12.txt AC 1 ms 512 KB
13.txt AC 1 ms 640 KB
14.txt AC 1 ms 640 KB
15.txt AC 1 ms 640 KB
16.txt AC 1 ms 640 KB
17.txt AC 1 ms 640 KB
18.txt AC 1 ms 640 KB
19.txt AC 1 ms 640 KB
20.txt AC 1 ms 640 KB
21.txt AC 1 ms 640 KB
22.txt AC 1 ms 640 KB
23.txt AC 1 ms 640 KB
24.txt AC 1 ms 640 KB
25.txt AC 1 ms 640 KB
26.txt AC 1 ms 640 KB
27.txt AC 1 ms 640 KB
28.txt AC 1 ms 640 KB
29.txt AC 1 ms 640 KB
30.txt AC 1 ms 640 KB