大一下一直困扰我的问题,终于在大二下完成了
明天蓝桥杯了,希望能保三争二吧,不知道有没有希望
#include
typedef long long ll;
using namespace std;
int main(){
int n;
cin>>n;
int l=0,r=n-1,u=0,b=n-1;
int tar=n*n;
int arr[n][n];
int now=1;
while(now<tar){
for(int i=l;i<=r;i++) arr[u][i]=now++;
u++;
for(int i=u;i<=b;i++) arr[i][r]=now++;
r--;
for(int i=r;i>=l;i--) arr[b][i]=now++;
b--;
for(int i=b;i>=u;i--) arr[i][l]=now++;
l++;
}
for(int i=0;i<n;i++){
for(int j=0;j<n;j++){
cout<<setfill(' ')<<setw(4)<<arr[i][j];
}
cout<<endl;
}
return 0;
}
如果有错误,还望指正,多谢
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)