Submission #1174724


Source Code Expand

#include <bits/stdc++.h>
using namespace std;
using ll=long long;

ll MAX_N=1e18+7;
ll mod=1e9+7;
ll dp[61][3];

int main(){
	ll N;
	cin>>N;
	dp[60][0]=1;
	for(ll a=59;a>=0;--a){
		for(ll b=0;b<=2;++b){
			for(ll c=0;c<=2;++c){
				ll d=b*2+(N>>a&1)-c;
				if(d<0)continue;
				if(d>2)d=2;
				dp[a][d]+=dp[a+1][b];
				dp[a][d]%=mod;
			}
		}
	}
	ll ret=0;
	for(ll i=0;i<=2;++i)ret+=dp[0][i];ret%=mod;
	cout<<ret<<endl;
	return 0;
}

Submission Info

Submission Time
Task D - Xor Sum
User Veronica
Language C++14 (GCC 5.4.1)
Score 600
Code Size 462 Byte
Status AC
Exec Time 1 ms
Memory 256 KB

Judge Result

Set Name Sample All
Score / Max Score 0 / 0 600 / 600
Status
AC × 3
AC × 19
Set Name Test Cases
Sample sample_01.txt, sample_02.txt, sample_03.txt
All sample_01.txt, sample_02.txt, sample_03.txt, subtask_1_max_01.txt, subtask_1_rand_01.txt, subtask_1_rand_02.txt, subtask_1_rand_03.txt, subtask_1_rand_04.txt, subtask_1_rand_05.txt, subtask_1_small_rand_01.txt, subtask_1_small_rand_02.txt, subtask_1_small_rand_03.txt, subtask_1_small_rand_04.txt, subtask_1_small_rand_05.txt, subtask_1_specific_01.txt, subtask_1_specific_02.txt, subtask_1_specific_03.txt, subtask_1_specific_04.txt, subtask_1_specific_05.txt
Case Name Status Exec Time Memory
sample_01.txt AC 1 ms 256 KB
sample_02.txt AC 1 ms 256 KB
sample_03.txt AC 1 ms 256 KB
subtask_1_max_01.txt AC 1 ms 256 KB
subtask_1_rand_01.txt AC 1 ms 256 KB
subtask_1_rand_02.txt AC 1 ms 256 KB
subtask_1_rand_03.txt AC 1 ms 256 KB
subtask_1_rand_04.txt AC 1 ms 256 KB
subtask_1_rand_05.txt AC 1 ms 256 KB
subtask_1_small_rand_01.txt AC 1 ms 256 KB
subtask_1_small_rand_02.txt AC 1 ms 256 KB
subtask_1_small_rand_03.txt AC 1 ms 256 KB
subtask_1_small_rand_04.txt AC 1 ms 256 KB
subtask_1_small_rand_05.txt AC 1 ms 256 KB
subtask_1_specific_01.txt AC 1 ms 256 KB
subtask_1_specific_02.txt AC 1 ms 256 KB
subtask_1_specific_03.txt AC 1 ms 256 KB
subtask_1_specific_04.txt AC 1 ms 256 KB
subtask_1_specific_05.txt AC 1 ms 256 KB