網站首頁 編程語言 正文
按理來說,楊輝三角是一個非常經典的問題,以至于隨手一搜遍地的代碼,但是今天在使用c++實現時遇到了問題,百度出來的沒有一個是我想要的答案,所以有了此文。
前言
本文主要講述了楊輝三角c和c++的具體實現,均為動態。
一、楊輝三角是什么
楊輝三角是二項式系數的集合排列。
具體實現:
是第i行j列的數據是由上一列第j個和j-1個數據相加得到的。
二、C語言版實現步驟
1.開辟動態二維數組
首先開辟一個存儲指針的地址的數組,即二級指針用來存放數據。
下一步便是給每一個二級指針的每個元素開辟空間。
代碼如下(示例):
int** Creat(int m) { // 楊輝三角每行數據與行數相同 //先開二級指針 int** triAngle = (int**)malloc(sizeof(int*) * m); assert(triAngle); // 再開二級指針中每個元素存儲數據的數組 for (size_t i = 0; i < m; i++) { triAngle[i] = (int*)malloc(sizeof(int) * (i + 1)); } return triAngle; }
2.初始化
楊輝三角的兩個等腰邊的數字是1,數學規律也比較好找,即每行第0個和最后一個是1,接下來就是開頭提到的內部的規律:
是第i行j列的數據是由上一列第j個和j-1個數據相加得到的。
代碼如下(示例):
void Init(int** triAngle, int m) { // 先將兩腰上的數據初始化為1 for (size_t i = 0; i < m; i++) { if (i == 0) { triAngle[i][0] = 1; } else { triAngle[i][0] = triAngle[i][i - 1] = 1; } } // 構建楊輝三角 for (size_t i = 0; i < m; i++) { for (size_t j = 0; j < i; j++) { if (triAngle[i][j] != 1) { triAngle[i][j] = triAngle[i - 1][j] + triAngle[i - 1][j - 1]; } } } }
3.打印
兩層for循環遍歷二維數組進行訪問然后打印。
代碼如下(示例):
void Print(int** triAngle, int m) { for (size_t i = 0; i < m; i++) { for (size_t j = 0; j < i; j++) { printf("%d ", triAngle[i][j]); } printf("\n"); } }
4.銷毀
首先釋放一級指針,再釋放存放它們的二級指針。
代碼如下(示例):
void Destory(int** triAngle, int m) { for (size_t i = 0; i < m; i++) { free(triAngle[i]); } free(triAngle); }
二、C++版實現步驟
1.實現類的成員變量
楊輝三角只需要一個成員變量:二維數組(兩個int的vector嵌套)
存放二維數組的行和列可以用_vv.size()和_vv[i].size()來表示。
代碼如下(示例):
class Yanghui { private: vector<vector<int>> _vv; size_t _n; };
2.實現成員函數
與c語言版相同,也需要創建、初始化、銷毀。
創建&初始化
我將創建函數實現為了構造函數,目的是為了不用調用,創建的時候就是開辟好的且已經初始化好的vector<vector<int>>。
代碼如下(示例):
// 構建實現為構造函數就不用調用了 Yanghui(int n = 5) { _vv.resize(n); for (size_t i = 0; i < _vv.size(); i++) { _vv[i].resize(i + 1); } // 先初始化兩腰數據為1 for (size_t i = 0; i < _vv.size(); i++) { _vv[i][0] = _vv[i][_vv[i].size() - 1] = 1; } // 構建楊輝三角 for (size_t i = 0; i < _vv.size(); i++) { for (size_t j = 0; j < _vv[i].size(); j++) { if (_vv[i][j] != 1) { _vv[i][j] = _vv[i - 1][j] + _vv[i - 1][j - 1]; } } } }
打印
代碼如下(示例):
void Print(int n) { for (size_t i = 0; i < n+1; i++) { for (size_t j = 0; j < i; j++) { cout << _vv[i][j] << " "; } cout << endl; } }
3.類的總體
代碼如下(示例):
#include <vector> using namespace std; class Yanghui { public: // 構建實現為構造函數就不用調用了 Yanghui(int n = 5) { _vv.resize(n); for (size_t i = 0; i < _vv.size(); i++) { _vv[i].resize(i + 1); } // 先初始化兩腰數據為1 for (size_t i = 0; i < _vv.size(); i++) { _vv[i][0] = _vv[i][_vv[i].size() - 1] = 1; } // 構建楊輝三角 for (size_t i = 0; i < _vv.size(); i++) { for (size_t j = 0; j < _vv[i].size(); j++) { if (_vv[i][j] != 1) { _vv[i][j] = _vv[i - 1][j] + _vv[i - 1][j - 1]; } } } } void Print() { for (size_t i = 0; i < _vv.size(); i++) { for (size_t j = 0; j < _vv[i].size(); j++) { cout << _vv[i][j] << " "; } cout << endl; } } ~Yanghui() { cout << "~Yanghui()" << endl; } private: vector<vector<int>> _vv; }; int main() { Yanghui triAngle(5); triAngle.Print(); return 0; }
原文鏈接:https://blog.csdn.net/leadera_/article/details/128767788
相關推薦
- 2022-04-12 C#實現六大設計原則之迪米特法則_C#教程
- 2022-10-05 帶你深度走入C語言取整以及4種函數_C 語言
- 2022-09-04 使用Docker容器部署MongoDB并支持遠程訪問及遇到的坑_docker
- 2022-05-11 使用postman訪問k8s api
- 2022-10-28 Go語言包和包管理詳解_Golang
- 2023-07-09 css樣式重疊解決辦法
- 2022-08-13 服務器上Redis主從復制和哨兵機制的配置
- 2022-09-15 Python淺析迭代器Iterator的使用_python
- 最近更新
-
- window11 系統安裝 yarn
- 超詳細win安裝深度學習環境2025年最新版(
- Linux 中運行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎操作-- 運算符,流程控制 Flo
- 1. Int 和Integer 的區別,Jav
- spring @retryable不生效的一種
- Spring Security之認證信息的處理
- Spring Security之認證過濾器
- Spring Security概述快速入門
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權
- redisson分布式鎖中waittime的設
- maven:解決release錯誤:Artif
- restTemplate使用總結
- Spring Security之安全異常處理
- MybatisPlus優雅實現加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務發現-Nac
- Spring Security之基于HttpR
- Redis 底層數據結構-簡單動態字符串(SD
- arthas操作spring被代理目標對象命令
- Spring中的單例模式應用詳解
- 聊聊消息隊列,發送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠程分支