您的位置:首页 > 其它

NYOJ33-蛇形填数

2018-03-17 18:17 260 查看

蛇形填数

时间限制:3000 ms  |  内存限制:65535 KB难度:3描述在n*n方陈里填入1,2,...,n*n,要求填成蛇形。例如n=4时方陈为:
10 11 12 1
9 16 13 2
8 15 14 3
7 6 5 4
输入直接输入方陈的维数,即n的值。(n<=100)输出输出结果是蛇形方陈。样例输入
3
样例输出
7 8 1
6 9 2
5 4 3

#include <stdio.h>  
main()  
{  
    int n,a[101][101]={0},x,y,c=0;  
    scanf("%d",&n);  
    x=0;y=n-1;  
    c=a[x][y]=1;  
    while (c<n*n)//最大数为n*n  
    {  

        while (x+1<n&&!a[x+1][y])//向下  
            a[++x][y]=++c;  
        while (y-1>=0&&!a[x][y-1])//向左  
            a[x][--y]=++c;  
        while (x-1>=0&&!a[x-1][y])//向上  
            a[--x][y]=++c; 
while (y+1<n&&!a[x][y+1])//向右  
            a[x][++y]=++c;  
    }     
        for (x=0;x<n;x++)  
    {  
        for (y=0;y<n;y++)  
            printf("%4d ",a[x][y]);  
        printf("\n");  
    }  
  return 0;
}  
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: