一个蛇形填充n×n矩阵的算法

该程序实现了一个蛇形填充n×n矩阵的算法。通过定义方向变量d(0表示右上,2表示左下),交替进行对角线填充:当向右上方超出边界时转向左下方,反之亦然。填充从a[0][0]=1开始,依次递增至n²。最后通过printArr函数输出填充完成的矩阵。核心逻辑是通过判断边界条件动态调整填充方向,实现蛇形走位填充二维数组。该算法时间复杂度为O(n²),空间复杂度为O(n²)。

cpp 复制代码
#include <stdio.h>
#include <math.h>

#define M  1001
int a[M][M];


void fun(int n){
	int k=1,i=0,j=0;
	int d =0;  //0右上角    2左下角 
	a[0][0]=k;
	
	while(k<=n*n){
		k++;
		if(d==0){ //右上角  i--,j++ 
			i--,j++;
			if(j==n){ //超出右边了, 
				i+=2,j--;
				d=2; //改方向 
			}else if(i<0){
				i++;
				d=2; //改方向 
			}
			a[i][j]=k;			
			continue;
		}
		if(d==2){//左下角 
			i++,j--;
			if(i==n){
				i--,j+=2;
				d=0;
			}else if(j<0){
				j++;
				d=0;
			}
			a[i][j]=k;			
			continue;
		}
		
	}
}

printArr(int n){
	int i,j;
	for(i=0;i<n;i++){
		for(j=0;j<n;j++)
			printf("%d ",a[i][j]);
		puts("");
	}
}

int main() {    
	int n;
	scanf("%d",&n);
	fun(n);
	printArr(n);
    return 0;
}
相关推荐
福尔摩斯张1 小时前
Axios源码深度解析:前端请求库设计精髓
c语言·开发语言·前端·数据结构·游戏·排序算法
算法与编程之美2 小时前
提升minist的准确率并探索分类指标Precision,Recall,F1-Score和Accuracy
人工智能·算法·机器学习·分类·数据挖掘
MicroTech20252 小时前
微算法科技(NASDAQ :MLGO)混合共识算法与机器学习技术:重塑区块链安全新范式
科技·算法·区块链
李牧九丶2 小时前
从零学算法1334
前端·算法
在繁华处2 小时前
C语言经典算法:汉诺塔问题
c语言·算法
思成不止于此3 小时前
【C++ 数据结构】二叉搜索树:原理、实现与核心操作全解析
开发语言·数据结构·c++·笔记·学习·搜索二叉树·c++40周年
爪哇部落算法小助手3 小时前
每日两题day50
数据结构·c++·算法
curry____3034 小时前
基本算法(2025.11.21)
c++·算法
WWZZ20255 小时前
快速上手大模型:深度学习5(实践:过、欠拟合)
人工智能·深度学习·神经网络·算法·机器人·大模型·具身智能
司铭鸿5 小时前
图论中的协同寻径:如何找到最小带权子图实现双源共达?
linux·前端·数据结构·数据库·算法·图论