網站首頁 編程語言 正文
前言:
本次蛇形矩陣我將以兩種方法來實現,即非遞歸和遞歸
非遞歸的實現:
#define right 1 #define down 2 #define left 3 #define up 4 #define n 5 //控制矩形的大小 #include<stdio.h> int main()//設計一個蛇形矩形圖案 順時針 { int m = 1; int x = 1; int y = 1; int direct; int i = 0; int j = 0; int arr[n + 1][n + 1]; for (x = 1; x < (n + 1); x++) { for (y = 1; y < (n + 1); y++) { arr[x][y] = 100;//隨機但是不能定為零 } } x = 1; y = 1; direct = right; while (m <= n * n) { arr[x][y] = m++; switch (direct) { case right: if (arr[x][y + 1] == 100) { y++; } else { direct = down; x++; }break; case down: if (arr[x + 1][y] == 100) { x++; } else { direct = left; y--; }break; case left: if (arr[x][y - 1] == 100) { y--; } else { direct = up; x--; }break; case up: if (arr[x - 1][y] == 100) { x--; } else { direct = right; y++; }break; } } //顯示矩形 for (x = 1; x <= n; x++) { for (y = 1; y <= n; y++) { printf("%2d ", arr[x][y]); } printf("\n"); } return 0; }
非遞歸的解題思想:定義一個數組,這個數組的大小是(N+1)*(N+1),目的是形成一個邊框,便于調整方向,其次就是當x與y跑到邊框的位置就實現拐彎。
拐彎的思想就是上到下,下到左,左到上,上再到右,實現從外圍向內包圍,直至m <= n * n。
遞歸的實現:
#define right 1 #define down 2 #define left 3 #define up 4 #define n 7 //控制大小 int arr[n][n]; #include<stdio.h> void snake(int x, int y, int m, int direct) { arr[x][y]=m; if (m == n * n) return; switch (direct) { case right: if ((y+1) == (n+1) || arr[x][y+1] > 0) {//到達右邊邊界或者右邊有數字,不能再往右 direct = down; //改變方向,向下 x++; //向下移動一格 } else //可以向右填寫 y++; //向右移動一格 break; case down: if ((x + 1) == (n+1) || arr[x + 1][y] > 0) { direct = left; y--; } else x++; break; case left: if ((y + 1) == (n+1) || arr[x][y - 1] > 0) { direct = up; x--; } else y--; break; case up: if ((y + 1) == (n+1) || arr[x-1][y] > 0) { direct = right; y++; } else x--; break; } snake(x, y, ++m, direct); //填寫下一個數 } int main()//用遞歸填寫這個矩形蛇形圖案 { int x = 1; int y = 1; int m = 1; snake(x, y, m, right); //顯示矩形 for (x = 1; x <= n; x++) { for (y = 1; y <= n; y++) { printf("%2d ", arr[x][y]);//這里有個二,別忘了 } printf("\n"); } return 0; }
遞歸的實現大體思路跟非遞歸的實現類似,從外面到內部
但遞歸的每一個元素是單獨在一個函數里來定義的,直至最后的m==n*n,然后再main函數里實現最終的模型。
其中的n是來控制大小,例如當n為5和9的結果如下:
原文鏈接:https://z-ming.blog.csdn.net/article/details/122353383
相關推薦
- 2022-03-17 .net?程序通過?crontab?無法啟動手動執(zhí)行腳本啟動的方法_實用技巧
- 2022-01-20 淺談關于 && , || , ? : , ?? , ?. 的運算方式以及用法
- 2024-02-29 UNI-APP開發(fā)之插件安裝失敗,離線安裝
- 2022-09-16 Go語言入門學習之Channel通道詳解_Golang
- 2022-06-14 Pycharm安裝第三方庫的超詳細步驟_python
- 2022-07-10 Executor 線程池技術詳解
- 2022-07-08 正則表達式中問號(?)的正確用法詳解_正則表達式
- 2022-05-11 JVM內存模型深度剖析與優(yōu)化
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細win安裝深度學習環(huán)境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發(fā)現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態(tài)字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支