码迷,mamicode.com
首页 > 其他好文 > 详细

NYOJ 852 蛇形填数(二)

时间:2015-07-03 20:36:36      阅读:110      评论:0      收藏:0      [点我收藏+]

标签:

#include<stdio.h>
int t=0,num,x,y,tot=0,n,i,j,sum=0;
#include<string.h>
#define max 1001
int a[max][max];
int main()
{
  scanf("%d",&num);
  while(num--)
  {
    scanf("%d",&n);
    for(i=1;i<=n;i++)
      sum=sum+i;
    memset(a,0,sizeof(a));
    tot=a[x=0][y=0]=1;
    while(tot<sum)
    {
      while(y+1<n && !a[x][y+1]) a[x][++y]=++tot;
      while(x+1<n && !a[x+1][y-1]) a[++x][--y]=++tot;
      while(x-1>=0 && !a[x-1][y]) a[--x][y]=++tot;
    }
    for(i=0;i<n;i++)
    {
      for(j=0;j<n-i;j++)
        printf("%d ",a[i][j]);
      printf("\n");
    }
    if(t<num)
      printf("\n");
    else
      t++;
    sum=0;
  }
}

NYOJ 852 蛇形填数(二)

标签:

原文地址:http://www.cnblogs.com/mycapple-zgs-111411/p/4619623.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!