lightoj-1008 - Fibsieve`s Fantabulous Birthday【思维】【找规律】
来源:互联网 发布:淘宝店铺pc端装修视频 编辑:程序博客网 时间:2024/05/16 18:34
题目链接:点击打开链接
Fibsieve had a fantabulous (yes, it's an actual word) birthday party this year. He had so many gifts that he was actually thinking of not having a party next year.
Among these gifts there was an N x N glass chessboard that had a light in each of its cells. When the board was turned on a distinct cell would light up every second, and then go dark.
The cells would light up in the sequence shown in the diagram. Each cell is marked with the second in which it would light up.
(The numbers in the grids stand for the time when the corresponding cell lights up)
In the first second the light at cell (1, 1) would be on. And in the 5th second the cell (3, 1) would be on. Now, Fibsieve is trying to predict which cell will light up at a certain time (given in seconds). Assume that N is large enough.
Input
Input starts with an integer T (≤ 200), denoting the number of test cases.
Each case will contain an integer S (1 ≤ S ≤ 1015) which stands for the time.
Output
For each case you have to print the case number and two numbers (x, y), the column and the row number.
Sample Input
Output for Sample Input
3
8
20
25
Case 1: 2 3
Case 2: 5 4
Case 3: 1 5
题解:刚开始想这道题太麻烦没简化,就TLE,后来再一看,ZZ 啊刚开始就找了个对角线规律,规律都没找全面怪不得TLE
题解:蓝色的是 奇数的平方;红色的是 偶数的平方;黄色的是对角线:对角线满足规律 n * (n - 1)+ 1,其中 n 为行(列)数; 然后注意一下特殊情况就行了
#include<cstdio>#include<algorithm>#include<cstring>#include<cmath>#define LL long longusing namespace std;LL n;int main(){int t,text=0;scanf("%d",&t);while(t--){scanf("%lld",&n);LL b,a=(LL)sqrt(n);printf("Case %d: ",++text);if(a*a==n) //特殊情况 {if(a&1)printf("1 %lld\n",a);elseprintf("%lld 1\n",a);continue;}if(a&1){b=a*(a+1)+1;if(n<b)printf("%lld %lld\n",a+1-(b-n),a+1);elseprintf("%lld %lld\n",a+1,a+1-(n-b));}else{b=a*(a+1)+1;if(n<b)printf("%lld %lld\n",a+1,a+1-(b-n));elseprintf("%lld %lld\n",a+1-(n-b),a+1);}}return 0;}
- lightoj-1008 - Fibsieve`s Fantabulous Birthday【思维】【找规律】
- lightoj 1008 - Fibsieve`s Fantabulous Birthday 【数学 找规律】
- LightOJ 1008 - Fibsieve`s Fantabulous Birthday (规律)
- LightOJ-1008-Fibsieve`s Fantabulous Birthday [规律]
- 【思维】LightOj Fibsieve`s Fantabulous Birthday 1008
- LIGHTOJ-10081008 - Fibsieve`s Fantabulous Birthday(规律)
- 【LightOJ】1008 - Fibsieve`s Fantabulous Birthday(规律)
- Fibsieve`s Fantabulous Birthday 找规律
- Light OJ - 1008 - Fibsieve`s Fantabulous Birthday (数学找规律)
- lightoj 1008 - Fibsieve`s Fantabulous Birthday
- LightOJ 1008 - Fibsieve`s Fantabulous Birthday
- lightOJ 1008 - Fibsieve`s Fantabulous Birthday
- LightOJ-1008 Fibsieve`s Fantabulous Birthday
- 1008 - Fibsieve`s Fantabulous Birthday (lightoj)
- lightoj 1008 - Fibsieve`s Fantabulous Birthday 乱搞
- LightOJ 1008 Fibsieve`s Fantabulous Birthday
- Lightoj 1008 - Fibsieve`s Fantabulous Birthday
- LightOJ 1008 Fibsieve`s Fantabulous Birthday
- C++学习笔记之——map set 与 opencv中的数据结构 如 point 等不兼容
- & |运算小记
- Codeforces Round #332 (Div. 2)D. Spongebob and Squares
- 美团笔试题(JavaScript)
- java虚拟机垃圾回收
- lightoj-1008 - Fibsieve`s Fantabulous Birthday【思维】【找规律】
- Android学习笔记--3.Intent的使用
- java.lang.UnsatisfiedLinkError: com.android.tools.fd.runtime.IncrementalClassLoader$DelegateClassLoa
- Lightoj 1138 ( Trailing Zeroes (III))
- JavaEE完整技术体系文章陆续上映!!!
- Qt 延时
- 求乘方取模(快速幂+慢速乘法模板)
- [noip模拟赛]旅行Pod(spfa)
- 图的深度遍历