螺旋矩阵c++ 完整测试代码

这篇博客介绍了如何用C++实现一个计算并返回给定整数N的Spiral Matrix,包括奇数和偶数情况的处理,重点在于递归的四向填充算法。通过实例演示了从左到右、上到下、右到左和下到上的填充过程,最后以`number`变量作为输入,展示了实际应用的输出结果。
摘要由CSDN通过智能技术生成
#include<iostream>
using namespace std;
#include<vector>
/*
输入为N,不论奇偶数,圈数是N/2
N是奇数,中心位置数字是N*N,且坐标为[N/2,N/2],
N是偶数,没有中心位置数
*/
vector<vector<int>> SpiralMatrix(int N) {  //返回一个二维数组
	//使用vector定义一个二维数组  并初始化为0
	vector<vector<int>> v(N, vector<int>(N, 0));
	int num = 0;
	//c表示圈数
	for (int c = 0; c < N / 2; c++) {
		for (int j = c; j <N - c - 1;j++) {  //从左往右填写
			v[c][j] = ++num;
		}
		for (int k = c; k < N - c;k++) {  //从上往下填写
			v[k][N-c-1] = ++num;
		}
		for (int i = N - c - 1; i >c;i-- ) {      //从右往左
			v[N-c-1][i] = ++num;
		}
		for (int m = N - c - 1; m >c;m--) {  //从下往上                                                                                                    
			v[m][c] = ++num;
		}
	}
	if (N%2 != 0) {
		v[N / 2][N / 2] = N * N;
	}
	return v;
}
int main() {
	int number = 0;
	cout << "enter the number: ";
	cin >> number;
	vector<vector<int>>varr;
	varr=SpiralMatrix(number);
	for (vector<vector<int>>::iterator it = varr.begin(); it != varr.end(); it++) {
		for (vector<int>::iterator vit = (*it).begin(); vit != (*it).end(); vit++) {
			cout << *vit << "\t";
		}
		cout << endl;
	}
	system("pause");
	return 0;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值