蛇形填数(C++)
#include <iostream>//蛇形填數?
#include <iomanip>//控制輸出長度,方便數據對齊?
using namespace std;
int main()
{
int a[101][101]={0};?
int i=1,k,j;
int n;
k=0;j=n-1;
cin>>n;
a[k][j]=1;
while(i!=n*n)
{
?while(k<n-1 && a[k+1][j]==0)
?{
? a[++k][j]=++i;
?}
?while(j>0 && a[k][j-1]==0)
?{
? a[k][--j]=++i;
?}?
?while(k>0 && a[k-1][j]==0)
?{
? a[--k][j]=++i;
?}
?while(j<n-1 && a[k][j+1]==0)
?{
? a[k][++j]=++i;
?}
? ? }
for(k=0;k<n;k++)
{
for(j=0;j<n;j++)
cout<<setw(3)<<setfill(' ')<<a[k][j];
cout<<endl;//不知道為什么不加setfill('') 程序運行就會出錯?
//printf("%4d",a[k][j]);
//printf("\n");
? ? }
return 0;
}
#include <iomanip>//控制輸出長度,方便數據對齊?
using namespace std;
int main()
{
int a[101][101]={0};?
int i=1,k,j;
int n;
k=0;j=n-1;
cin>>n;
a[k][j]=1;
while(i!=n*n)
{
?while(k<n-1 && a[k+1][j]==0)
?{
? a[++k][j]=++i;
?}
?while(j>0 && a[k][j-1]==0)
?{
? a[k][--j]=++i;
?}?
?while(k>0 && a[k-1][j]==0)
?{
? a[--k][j]=++i;
?}
?while(j<n-1 && a[k][j+1]==0)
?{
? a[k][++j]=++i;
?}
? ? }
for(k=0;k<n;k++)
{
for(j=0;j<n;j++)
cout<<setw(3)<<setfill(' ')<<a[k][j];
cout<<endl;//不知道為什么不加setfill('') 程序運行就會出錯?
//printf("%4d",a[k][j]);
//printf("\n");
? ? }
return 0;
}
總結
- 上一篇: HDU2023求平均成绩
- 下一篇: 简单的石头剪刀布(机器胜率略高)