回形数组的输出

二维数组的回形输出
这篇博客主要展示了如何实现回形矩阵(二维数组)的打印,重点讨论了确定边界条件的方法,即如何处理最后几个输出的情况。

代码如下,打印回形矩阵或者说二维数组:

#include<stdio.h>
#include<string.h>
int main()
{
	int m,n;
	scanf("%d %d",&m,&n);
	int a[100][100]={};
	for (int i=0;i<m;i++) 
		for (int j=0;j<n;j++) 
			scanf("%d",&a[i][j]);              //做题目时的读取输入
	int k=m;
	int l=n;
	while(2*k>=m&&2*l>=n)
	{
		for(int p=n-l;p<l-1;p++) printf("%d\n",a[m-k][p]);                //把数字一行行剥掉
		for(int q=m-k;q<k-1;q++) printf("%d\n",a[q][l-1]);
		if(m-k!=k-1)
			for(int r=l-1;r>n-l;r--) printf("%d\n",a[k-1][r]);    //这里判断边界,以下同
		else
			printf("%d\n",a[k-1][l-1]);
		if(n-l!=l-1)
			for(int s=k-1;s>m-k;s--) printf("%d\n",a[s][n-l]);
		else if(m-k!=k-1)
			printf("%d\n",a[k-1][n-l]);
		k--;
		l--;
	}
	return 0;
}

这种做法重点在于边界条件的确定:边界指的是最后的那几个输出

或者

#include<stdio.h>
#include<string.h>
int main()
{
	int m,n;
	scanf("%d %d",&m,&n);
	int a[100
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值