POJ 3070 Fibonacci

原题

#include <iostream>
#include <vector>
#include <cstdio>
using namespace std;
const int MAXN = 100;
const int MOD = 10000;
struct Matrix
{
	vector< vector<int> > a;
	int n, m;
	Matrix(int n, int m) : n(n), m(m)
	{
		a.resize(n);
		for (int i = 0; i < n; i++) a[i].resize(m);
	}
	void cpy(const Matrix &B)
	{
		n = B.n;
		m = B.m;
		a.resize(n);
		for (int i = 0; i < n; i++)
		for (int j = 0; j < m; j++) {
			a[i].resize(m);
			a[i][j] = B.a[i][j] % MOD;
		}
	}
	void multiply(const Matrix &B)
	{
		//if (m != B.n) exit(250);
		Matrix t(n, B.m);
		for (int i = 0; i < n; i++)
		for (int j = 0; j < B.m; j++)
		for (int k = 0; k < m; k++)
			t.a[i][j] = (t.a[i][j] + a[i][k] * B.a[k][j]) % MOD;
		cpy(t);
	}
	void print()
	{
		for (int i = 0; i < n; i++) {
			cout << endl;
			for (int j = 0; j < m; j++)
				cout << ' ' << a[i][j];
		}
	}
	void eye()
	{
		for (int i = 0; i < n; i++) a[i][i] = 1;
	}
	void power(int p)
	{
		Matrix res(n, m);
		res.eye();
		Matrix t(n, m);
		t.cpy(*this);
		while (p)
		{
			if (p & 1) res.multiply(t);
			p >>= 1;
			t.multiply(t);
		}
		cpy(res);
	}
};
void solve(int n)
{
	Matrix a(2, 1);
	a.a[0][0] = 0;
	a.a[1][0] = 1;
	Matrix b(2, 2);
	b.a[0][0] = 1; b.a[0][1] = 1;
	b.a[1][0] = 1; b.a[1][1] = 0;
	b.power(n);
	//b.print();
	b.multiply(a);
	cout << b.a[0][0] << endl;
}
int main()
{
	//freopen("in", "r", stdin);
	int n;
	for (;;) {
		scanf("%d", &n);
		if (n == -1) break;
		solve(n);
	}
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值