답안 #421447

# 제출 시각 아이디 문제 언어 결과 실행 시간 메모리
421447 2021-06-09T07:31:52 Z Nicholas_Patrick 수열 (BOI14_sequence) C++17
25 / 100
77 ms 880 KB
#pragma GCC optimize("O3")
#include <cstdio>
#include <queue>
#include <random>
using namespace std;

long long count=0;
int singleLookup[1024];
int single(int mask){
	long long ret=0, mult=1;
	if(mask==1)
		return 10;
	for(int i=10; --i;){
		if(mask>>i&1){
			ret+=mult*i;
			mult*=10;
		}
	}
	if(mask&1){
		mult/=10;
		ret+=ret/mult*mult*9;
	}
	return ret;
}
long long solve(vector<int>& masks, int depth=0, bool positive=true){
	if(depth>=15)
		return 1;
	if(masks.size()==0)
		return positive;
	if(masks.size()==1){
		int ret=singleLookup[masks[0]];
		return ret?ret:positive;
	}
	long long ret=102345678888889;
	for(int fu=0; fu<10; fu++){
		vector<int> newMasks((masks.size()-1+fu)/10+1, 0);
		bool reduced=false;
		for(int i=0; i<10; i++){
			int u=fu+i;
			bool additional=u>=10;
			if(additional)
				u-=10;
			for(int j=0; j*10+i<masks.size(); j++){
				int x=masks[j*10+i]&~(1<<u);
				reduced|=x!=masks[j*10+i];
				newMasks[j+additional]|=x;
			}
		}
		if(not reduced)
			continue;
		while(not newMasks.empty() and newMasks.back()==0)
			newMasks.pop_back();
		ret=min(ret, solve(newMasks, depth+1, fu==0)*10+fu);
	}
	if(ret==0)
		ret=positive;
	return ret;
}
int main(){
	for(int i=0; i<1024; i++)
		singleLookup[i]=single(i);
	int k;
	scanf("%d", &k);
	vector<int> b(k);
	for(int& i : b)
		scanf("%d", &i), i=1<<i;
	printf("%lld\n", solve(b));
	// printf("%.3lf\n", (double)clock()/CLOCKS_PER_SEC);
}

Compilation message

sequence.cpp: In function 'long long int solve(std::vector<int>&, int, bool)':
sequence.cpp:43:23: warning: comparison of integer expressions of different signedness: 'int' and 'std::vector<int>::size_type' {aka 'long unsigned int'} [-Wsign-compare]
   43 |    for(int j=0; j*10+i<masks.size(); j++){
      |                 ~~~~~~^~~~~~~~~~~~~
sequence.cpp: In function 'int main()':
sequence.cpp:63:7: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   63 |  scanf("%d", &k);
      |  ~~~~~^~~~~~~~~~
sequence.cpp:66:8: warning: ignoring return value of 'int scanf(const char*, ...)' declared with attribute 'warn_unused_result' [-Wunused-result]
   66 |   scanf("%d", &i), i=1<<i;
      |   ~~~~~^~~~~~~~~~
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 204 KB Output is correct
2 Incorrect 1 ms 204 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 204 KB Output is correct
2 Incorrect 1 ms 204 KB Output isn't correct
3 Halted 0 ms 0 KB -
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 204 KB Output is correct
2 Correct 12 ms 348 KB Output is correct
3 Correct 16 ms 332 KB Output is correct
4 Correct 9 ms 332 KB Output is correct
5 Correct 10 ms 356 KB Output is correct
6 Correct 6 ms 332 KB Output is correct
7 Correct 41 ms 716 KB Output is correct
8 Correct 49 ms 460 KB Output is correct
9 Correct 77 ms 876 KB Output is correct
10 Correct 69 ms 880 KB Output is correct
# 결과 실행 시간 메모리 Grader output
1 Correct 1 ms 204 KB Output is correct
2 Incorrect 1 ms 204 KB Output isn't correct
3 Halted 0 ms 0 KB -