递归规范写法(P1762 偶数)

打表(杨辉三角一般都是规律题)
#include<bits/stdc++.h>
using namespace std;
int n;
int f[102][102];
int main(){
	f[0][0]=1;
	for(int i=1;i<=50;++i){
		//cout << i << ": ";
		printf("%3d: ",i);
		for(int j=1;j<=i;++j){
			f[i][j]=f[i-1][j]+f[i-1][j-1];
			if(f[i][j]%2) cout << "*";
			else cout << '.';
		}
		cout << "\n";
	}
	return 0;
} 

观察得: f(2+ t)=3*f(2k-1)+2* f ( t )     【f(1)=1】
==>         f(2+ t)= 3+ 2* f ( t ) 

#include<bits/stdc++.h>
using namespace std;
#define ll long long
int const mod=1000003;
ll ksm(ll a,ll b){
	ll res=1;
	while(b){
		if(b&1) (res*=a)%=mod;
		b >>= 1;
		a*=a;
		a%=mod;
	}
	return res;
}
int v[57];
ll v2[57],ans,sum;
int f(ll& n){
	if(n==1) return 1;
	ll k=log(n)/log(2);
	n-=v2[k];
	ll res=0;
	res+=v[k];
	if(n) res+=2*f(n);  //if优秀的剪枝 
	if(res>mod) {
		res-=res/mod*mod;
	}
	return res;
}
ll n;
int main(){
	cin >> n;
	v[0]=1;v2[0]=1;
	for(int i=1;i<=52;++i){
		v[i]=v[i-1]*3%mod;
		v2[i]=v2[i-1]*2;
	}
	ll z=n%mod;
	ans=(z+1)* ksm(2,mod-2)%mod*z%mod;
	ans-=f(n);
	ans=(ans%mod+mod)%mod;
	cout << ans;
	return 0;
}


全部评论

相关推荐

ResourceUtilization:差不多但是估计不够准确,一面没考虑到增长人口,另一方面也没考虑到能上大学的人数比例,不过我猜肯定只多不少
点赞 评论 收藏
分享
求面试求offer啊啊啊啊:要求太多的没必要理
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客企业服务