进阶训练一.水题
2016-01-03 11:08
295 查看
Description
A number sequence is defined as follows:f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * f(n - 2)) mod 7.
Given A, B, and n, you are to calculate the value of f(n).
Input
The input consists of multiple test cases. Each test case contains 3 integers A, B and n on a single line (1 <= A, B <= 1000, 1 <= n <= 100,000,000). Three zeros signal the end of input and this test case is not to be processed.Output
For each test case, print the value of f(n) on a single line.Sample Input聽
1 1 31 2 10
0 0 0
Sample Output
25
分析:水题一枚。这题的特点在于如果要自己找规律的话非常难找,因为f(n-1)有可能是0-6,f(n-2)也是,共49种可能,所以最好的方法是设计程序让程序找规律
代码:
#include<stdio.h> int main() { int i, j, n,a,b,begin,end,flag,str[60]; while (1) { scanf("%d%d%d", &a, &b, &n); if (a == 0 && b == 0 && n == 0) break; str[1] = str[2] = 1; flag = 0; for (i = 3;i <= n&&!flag;i++) { str[i] = (a*str[i - 1] + b*str[i - 2]) % 7; for (j = 2;j < i;j++) { if (str[i - 1] == str[j - 1] && str[i - 2] == str[j - 2]) { flag = 1; begin = j; end = i; break; } } } if (flag) printf("%d\n", str[begin + (n - end) % (end - begin)]); else printf("%d\n", str ); } return 0; }
相关文章推荐
- bzoj2730: [HNOI2012]矿场搭建
- 基于javascript实现简单计算器功能
- Unity中使用ulua的个人经验总结
- 计算机网络学习(三)——网络层
- 逻辑斯蒂回归模型
- c++ --单例的实现
- Delphi下 多显示器,将窗体显示于第二个显示器
- HDU 5607 graph
- 图片下载并保存到SD卡
- Java中Runnable和Thread的区别
- web开发中的路径问题
- Python 爬虫的实践运用(1)--爬取百度百科的词条
- Gradle for Android 第三篇( 依赖管理 )
- win10自带邮箱无法和163网易邮箱同步该怎么办?
- objectarx开发的环境设置
- 数据结构之一般树的基本操作
- css float 布局
- 详解Javascript事件驱动编程
- Find The Multiple
- AFN网络框架2.x版—网络监控