HDU 2446(搜索题,二分)
2010-07-25 22:04
337 查看
Shell Pyramid
Time Limit: 5000/1000 MS (Java/Others) Memory Limit: 32768/32768 K (Java/Others)Total Submission(s): 741 Accepted Submission(s): 277
Problem Description
In the 17th century, with thunderous noise, dense smoke and blazing fire, battles on the sea were just the same as those in the modern times. But at that time, the cannon ,were extremely simple. It was just like an iron cylinder, with its rearward end sealed and forward end open. There was a small hole at the rearward end of it, which was used to install the fuse. The cannons on the warships were put on small vehicles which had four wheels and the shells were iron spheres with gunpowder in them.
At that time, it was said that there was an intelligent captain, who was also a mathematician amateur. He liked to connect everything him met to mathematics. Before every battle, he often ordered the soldiers to put the shells on the deck and make those shells to form shell pyramids.
Now let's suppose that a shell pyramid has four layers, and there will be a sequence of ordinal numbers in every layer. They are as the following figure:
In the figure, they are the first layer, the second layer, the third layer and the fourth layer respectively from the left to the right.
In the first layer, there is just 1 shell, and its ordinal number is 1. In the second layer, there are 3 shells, and their ordinal numbers are 1, 2, and 3. In the third layer, there are 6 shells, and their ordinal numbers are 1, 2, 3, 4, 5, and 6. In the fourth layer, there are 10 shells, and their ordinal numbers are shown in the figure above.
There are also serial numbers for the whole shell pyramid. For example, the serial number for the third shell in the second layer is 4, the serial number for the fifth shell in the third layer is 9, and the serial number for the ninth shell in the fourth layer is 19.
There is also a interrelated problem: If given one serial number s, then we can work out the s th shell is in what layer, what row and what column. Assume that the layer number is i, the row number is j and the column number is k, therefore, if s=19, then i=4, j=4 and k=3.
Now let us continue to tell about the story about the captain.
A battle was going to begin. The captain allotted the same amount of shells to every cannon. The shells were piled on the deck which formed the same shell pyramids by the cannon. While the enemy warships were near, the captain ordered to fire simultaneously. Thunderous sound then was heard. The captain listened carefully, then he knew that how many shells were used and how many were left.
At the end of the battle, the captain won. During the break, he asked his subordinate a question: For a shell pyramid, if given the serial number s, how do you calculate the layer number i, the row number j and column number k?
Input
First input a number n,repersent n cases.For each case there a shell pyramid which is big enough, a integer is given, and this integer is the serial number s(s<2^63). There are several test cases. Input is terminated by the end of file.
Output
For each case, output the corresponding layer number i, row number j and column number k.
Sample Input
2 19 75822050528572544
Sample Output
4 4 3 769099 111570 11179#include <iostream> using namespace std; #define N 2000000 __int64 a ,b ; void init() { a[0]=0; int i; for(i=1;i<N;i++) { a[i]=i+a[i-1]; } b[0]=0; for(i=1;i<N;i++) { b[i]=b[i-1]+a[i]; } } int er_fen(__int64 n) { int low,high,mid; low=1; high=N; while(low+1!=high) { mid=(low+high)/2; if(b[mid]<n) low=mid; else if(b[mid]>n) high=mid; else { return mid; } } return low; } int er_fen1(__int64 n,int m) { int low,high,mid; low=1; high=m; while(low+1!=high) { mid=(low+high)/2; if(a[mid]<n) low=mid; else if(a[mid]>n) high=mid; else { return mid; } } return low; } int main() { int t,l,r,c; __int64 n,mid; init(); scanf("%d",&t); while(t--) { scanf("%I64d",&n); l=er_fen(n); if(b[l]==n) { printf("%d %d %d/n",l,l,l); } else { if(b[l]<n) l++; __int64 temp=n-b[l-1]; r=er_fen1(temp,l); if(a[r]==temp) { printf("%d %d %d/n",l,r,r); } else { if(a[r]<temp) r++; c=temp-a[r-1]; printf("%d %d %d/n",l,r,c); } } } return 0; }
相关文章推荐
- hdu 2446 二分搜索解题报告
- 【二分】 HDU 2446 Shell Pyramid
- HDU 5855 二分搜索+最大流
- hdu 2199 Can you solve this equation?(二分搜索)
- HDU-1969(二分搜索)
- hdu 5432 Pyramid Split(二分搜索)
- HDU 4803 Poor Warehouse Keeper 贪心 二分搜索
- hdu 2141 二分搜索
- hdu 1257 贪心+二分搜索
- SDAU训练日志第23篇----------搜索与查找二分hdu练习(1)(2018年3月16日)
- 简单搜索练习(一)二分入门 HDU 2141 Can you find it?POJ 2785 4 Value whose Sum is 0
- HDU 4024 Dwarven Sniper’s hunting (计算几何-其它,搜索-二分)
- 2-sat+二分搜索hdu(3622)
- HDU 2141(搜索题,二分)
- HDU 2289 Cup (二分搜索)
- HDU 3681 Prison Break 二分+搜索 The 35th ACM-ICPC Asia Regional Contest (Hangzhou)
- HDU_4004_The frog's game_二分搜索
- HDU 4024 Dwarven Sniper’s hunting (计算几何-其它,搜索-二分)
- 2-sat+二分搜索hdu(3622)
- hdu 4004 The Frog's Games (二分搜索 + 贪心)