C++面试题之螺旋队列
2010-12-18 12:40
274 查看
//螺旋队列.cpp
// 21 22 ... ...
// 20 7 8 9 10
// 19 6 1 2 11
// 18 5 4 3 12
// 17 16 15 14 13
//看清以上数字排列的规律,设1点的坐标是(0,0),X方向向右为正,y方向向下为正。例如,7的坐标为
//(-1,-1),2的坐标为(0,1),3的坐标为(1,1)。编程实现输入任意一点坐标(x,y),输出所对应得
//数字。[芬兰某著名通信设备公司2005年面试题]
#include<stdio.h>
#define max(a,b) ((a)<(b)?(b):(a))
#define abs(a) ((a)>0?(a):(-a))
int foo(int x,int y)
{
int t=max(abs(x),abs(y));
int u=t+t;
int v=u-1;
v=v*v+u;
if(x==-t) v+=u+t-y;
else if(y==-t)
v+=3*u+x-t;
else if (y==t)
v+=t-x;
else
v+=y-t;
return v;
}
int main()
{
int x,y;
for(y=-4;y<=4;y++)
{
for(x=-4;x<=4;x++)
printf("%5d",foo(x,y));
printf("/n");
}
while(scanf("%d%d",&x,&y)==2)
printf("%d/n",foo(x,y));
return 0;
}
// 21 22 ... ...
// 20 7 8 9 10
// 19 6 1 2 11
// 18 5 4 3 12
// 17 16 15 14 13
//看清以上数字排列的规律,设1点的坐标是(0,0),X方向向右为正,y方向向下为正。例如,7的坐标为
//(-1,-1),2的坐标为(0,1),3的坐标为(1,1)。编程实现输入任意一点坐标(x,y),输出所对应得
//数字。[芬兰某著名通信设备公司2005年面试题]
#include<stdio.h>
#define max(a,b) ((a)<(b)?(b):(a))
#define abs(a) ((a)>0?(a):(-a))
int foo(int x,int y)
{
int t=max(abs(x),abs(y));
int u=t+t;
int v=u-1;
v=v*v+u;
if(x==-t) v+=u+t-y;
else if(y==-t)
v+=3*u+x-t;
else if (y==t)
v+=t-x;
else
v+=y-t;
return v;
}
int main()
{
int x,y;
for(y=-4;y<=4;y++)
{
for(x=-4;x<=4;x++)
printf("%5d",foo(x,y));
printf("/n");
}
while(scanf("%d%d",&x,&y)==2)
printf("%d/n",foo(x,y));
return 0;
}
相关文章推荐
- 螺旋队列C++代码实现实例及运行结果
- 螺旋队列C++代码实现实例及运行结果
- 螺旋队列C++代码实现实例及运行结果
- C++笔试题(剑指offer 面试题7 两个栈实现队列)
- 面试题7:用两个栈实现队列的c++代码实现
- 面试题-螺旋队列
- C++面试题:两个队列实现一个栈
- 螺旋队列C++代码实现实例及运行结果
- 螺旋队列C++代码实现实例及运行结果
- c++面试准备之螺旋队列
- 用C++实现顺时针增加的螺旋队列
- [C++面试题]之循环链表、队列、栈和堆(在csdn上看到一道面试题—求解啊)
- 【C++面试题】:用两个队列模拟一个栈
- C++面试题 用俩个栈(队列)实现一个队列(栈)
- 螺旋队列C++代码实现实例及运行结果
- 剖析一道螺旋队列面试题
- c++面试准备之螺旋队列
- C/C++学习笔记22:螺旋队列
- 螺旋队列C++代码实现实例及运行结果
- C++螺旋队列算法分析