用户注册



邮箱:

密码:

用户登录


邮箱:

密码:
记住登录一个月忘记密码?

发表随想


还能输入:200字
云代码 - c++代码库

hdoj1005找规律

2013-02-02 作者: shiqiang举报

[c++]代码库

#include<iostream>
using namespace std;

int main(){
//如果仅仅用递归或递推都会超时
//关键:循环周期最大为49
	int a, b, c;
	int f1, f2, f3;
	int f4[51];
	f4[0] = f4[1] = 1;
	int index_i, index_j;
	for(cin>>a>>b>>c; a || b || c; cin>>a>>b>>c){
		f1 = 1;
		f2 = 1;
		for(int i = 2; i < 51; i++){//递推求解f(n)
			f3 = (a * f2 + b * f1) % 7;			
			int flag = 0;
			for(int j = 2; j < i; j++){//到数组中查找是否已有f(k)== f3;				
   				if(f4[j] == f3 && f4[j - 1] == f2 && f4[j - 2] == f1){
					index_i = i + 1;
					index_j = j + 1;					
					flag = 1;
					break;
				}
			}
			//cout<<"case f"<<i + 1<<" "<<f1<<" "<<f2<<" "<<f3<<" "<<endl;
			f1 = f2;
			f2 = f3;
			if(flag == 0){
				f4[i] = f3;
			}else{
				break;
			}
		}
		int temp;
		temp = (c - index_j) % (index_i - index_j);
		//cout<<index_j<<" "<<index_i<<endl;
		if(c > index_i - index_j){
			cout<<f4[index_j + temp - 1]<<endl;
		}else{
			cout<<f4[c - 1]<<endl;
		}
	}
	return 0;
}


网友评论    (发表评论)


发表评论:

评论须知:

  • 1、评论每次加2分,每天上限为30;
  • 2、请文明用语,共同创建干净的技术交流环境;
  • 3、若被发现提交非法信息,评论将会被删除,并且给予扣分处理,严重者给予封号处理;
  • 4、请勿发布广告信息或其他无关评论,否则将会删除评论并扣分,严重者给予封号处理。


扫码下载

加载中,请稍后...

输入口令后可复制整站源码

加载中,请稍后...