数字阶梯(Number Steps)
Starting from point (0,0) on a plane, we have written all non-negative
integers 0, 1, 2,... as shown in the figure. For example, 1, 2, and 3 has been
written at points (1,1), (2,0), and (3, 1) respectively and this pattern has
continued.
integers 0, 1, 2,... as shown in the figure. For example, 1, 2, and 3 has been
written at points (1,1), (2,0), and (3, 1) respectively and this pattern has
continued.
You are to write a program that reads the coordinates of a point (x, y), and
writes the number (if any) that has been written at that point. (x, y)
coordinates in the input are in the range 0...5000.
writes the number (if any) that has been written at that point. (x, y)
coordinates in the input are in the range 0...5000.
Input
The first line of the input is N, the number of test
cases for this problem. In each of the N following lines, there is x, and y
representing the coordinates (x, y) of a point.
Output
For each point in the input, write the number
written at that point or write No Number if there is none.
Sample Input
3
4 2
6 6
3 4
Sample Output
6
12
No Number
解答:
View Code
int main()
{
int N, i;
scanf("%d", &N); //N表示输入文件中测试数据的数目
int x, y;
for (i = 0; i < N; i++) //处理输入文件中的N个测试数据
{
scanf("%d %d", &x, &y); //每个测试数据包含两个整数
int Num; //在(x,y)坐标点上的非负整数
if (y != x && y != x-2)
{
Num = -1;
}
else
{
if (y == x && x % 2 == 0)
{
Num = 2 * x;
}
else if (y == x && x % 2 != 0)
{
Num = 2 * x - 1;
}
else if (y == x-2 && x%2 == 0)
{
Num = 2 * x -2;
}
else
{
Num = 2 * x -3;
}
}
if (Num == -1) printf("No Number\n");
else printf("%d\n", Num);
}
return 1;
}
作者:涵曦(www.hanxi.cc)
出处:hanxi.cnblogs.com
GitHub:github.com/hanxi
Email:im.hanxi@gmail.com
文章版权归本人所有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。
《 Skynet 游戏服务器开发实战》
-
学习地址:
-
优惠推荐码:
2CZ2UA5u
-
可以先免费试学前 2 章内容