Number Sequence(周期是336!!不是48!!)
1005 Number Sequence
时间限制: 1 Sec 内存限制: 60 MB
题目描述
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).
输入
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.
输出
For each test case, print the value of f(n) on a single line.
样例输入
1 1 3 1 2 10 0 0 0
样例输出
2 5
解题思路
显然,这是一个找周期的问题。
我们很容易推出,一定有周期,而且最小周期不超过49,(在下面,都假设a和b小于7,即已经%7),而且,如果a、b不全为0,那么一定是从第1项开始循环的,当a=b=0时,不是从第1项开始,而是从第3项开始循环。我一开始的方法是,对于每组给的a、b,求出最小正周期
代码:
#include <stdio.h>
/*找周期*/
int period(int a, int b)
{
int t = 0, f1 = 1, f2 = 1, temp;
if (a == 0 || b == 0)
return 12;
if ((a + b) % 7 == 1)
return 1;
while (1)
{
temp = (a * f1 + b * f2) % 7;
f2 = f1;
f1 = temp;
t++;
if (f1 == 1 && f2 == 1) /*再次遇到f1 = 1,f2 = 1的时候跳出*/
break;
}
return t;
}
int main()
{
int a, b, n, f1, f2, temp;
while (scanf("%d%d%d", &a, &b, &n), a, b, n)
{
if (a % 7 == 0 && b % 7 == 0)
{
printf("%d\n", n < 3);
continue;
}
f1 = 1, f2 = 1;
if (n > 20)
n = (n - 20) % period(a % 7, b % 7) + 20;
if (n > 2)
n -= 2;
else n = 0;
while (n--)
{
temp = (a * f1 + b * f2) % 7;
f2 = f1;
f1 = temp;
}
printf("%d\n", f1);
}
return 0;
}
我发现网上有有很多这道题的题解,代码很短,就看了一下,发现他们是直接以48为周期,甚至还有很多人说49是周期。。。
但是我枚举了a和b(一共也就49种情况),发现周期并不是48。
代码:
int main()
{
for (int i = 0; i < 7; i++)
{
for (int j = 0; j < 7; j++)
printf("%d ", period(i, j));
printf("\n");
}
return 0;
}
结果:
12 12 12 12 12 12 12 12 16 6 24 48 21 6 12 6 48 6 48 24 1 12 16 48 42 6 1 8 12 16 48 21 1 6 8 12 6 48 1 48 24 14 12 16 1 24 48 42 3
很明显,有14、21、42的存在,显然48不是周期!所以说,应该是OJ给的测试数据很水,有很多代码都浑水摸鱼了。但336一定是周期,所以就可以写出代码了。
代码:
#include <stdio.h>
int main()
{
int a, b, n, f1, f2, temp;
while (scanf("%d%d%d", &a, &b, &n), a, b, n)
{
if (a % 7 == 0 && b % 7 == 0)
{
printf("%d\n", n < 3);
continue;
}
f1 = 1, f2 = 1;
n = (n + 333) % 336 + 1;
while (n--)
{
temp = (a * f1 + b * f2) % 7;
f2 = f1;
f1 = temp;
}
printf("%d\n", f1);
}
return 0;
}Number Sequence(周期是336!!不是48!!)的更多相关文章
- A - Number Sequence(矩阵快速幂或者找周期)
Description A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) + B * ...
- HDU1005 Number Sequence(找规律,周期是变化的)
传送门: http://acm.hdu.edu.cn/showproblem.php?pid=1005 Number Sequence Time Limit: 2000/1000 MS (Java/O ...
- hdu1005 Number Sequence(数论)
Number Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others) Tot ...
- HDU 1005 Number Sequence【多解,暴力打表,鸽巢原理】
Number Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- HDU 1005 Number Sequence
Number Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- Number Sequence
Number Sequence A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1) ...
- hdu 1005:Number Sequence(水题)
Number Sequence Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 65536/32768 K (Java/Others)T ...
- Number Sequence (HDoj1005)
Problem Description A number sequence is defined as follows: f(1) = 1, f(2) = 1, f(n) = (A * f(n - 1 ...
- 1005 Number Sequence(HDU)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=1005 Number Sequence Time Limit: 2000/1000 MS (Java/O ...
随机推荐
- sublime 官方正版,自己用的插件配置,最轻量级安装流程
到了一家新公司,新的办公电脑,移动工作站哦,配置很酷.需要自己安装编码环境,node.js(http-server)是必须要装的,编辑器个人比较喜欢sublime,现在归纳一下配置流程,ps:本人有点 ...
- Shell命令-文件及目录操作之touch、tree
文件及目录操作 - touch.tree 1.touch:创建文件或更改文件时间戳 touch命令的功能说明 touch命令用于创建新的空文件或改变已有文件的时间戳属性. touch命令的语法格式 t ...
- Kivy 中文教程 实例入门 简易画板 (Simple Paint App):1. 自定义窗口部件 (widget)
1. 框架代码 用 PyCharm 新建一个名为 SimplePaintApp 的项目,然后新建一个名为 simple_paint_app.py 的 Python 源文件, 在代码编辑器中,输入以下框 ...
- 源码编译安装php7
现在新启的项目都是采用php7了,无奈很多Linux发行版中还是php5 第三方php7源在自己本机上用用到无所谓,放到正式环境上还是有点不放心 其实编译安装也就几分钟,麻烦的是各种依赖 先删除老版本 ...
- nginx(一)初识nginx
什么是nginx?Nginx (engine x) 是一款轻量级的Web 服务器 .反向代理服务器及电子邮件(IMAP/POP3)代理服务器. Nginx应用场景(都很常用): 1:http服务器.N ...
- linux添加超级管理员用户,修改,删除用户
useradd一个用户后,去修改/etc/passwd文件中的这个用户这一行,把其中的uid改为0,gid改为0(其中****代表一个用户名)这样****就具有root权限了 如:root2:x:0: ...
- [模板]Min_25筛
用途 快速($O(\frac{n^{3/4}}{logn})$)地计算一些函数f的前缀和,以及(作为中间结果的)只计算质数的前缀和 一般要求f(p)是积性函数,$f(p)$是多项式的形式,且$f(p^ ...
- To the moon HDU - 4348 (主席树,区间修改)
Background To The Moon is a independent game released in November 2011, it is a role-playing adventu ...
- 初识 go 语言:语法
目录 语法 for 循环 if 语句 switch 语句 defer 语句 defer 栈 结束 前言: go语言系列第二篇,主要讲述go语言的语法,如循环,if判断,swich语句,defer语句, ...
- Spring MVC 学习总结(一)——MVC概要与环境配置(IDea与Eclipse示例)
一.MVC概要 MVC是模型(Model).视图(View).控制器(Controller)的简写,是一种软件设计规范,用一种将业务逻辑.数据.显示分离的方法组织代码,MVC主要作用是降低了视图与业务 ...