日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程语言 > c/c++ >内容正文

c/c++

c++:栈的基本操作+实例:迷宫求解

發(fā)布時間:2025/4/16 c/c++ 24 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c++:栈的基本操作+实例:迷宫求解 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.

棧的基本操作+實例:迷宮求解

#include<iostream> using namespace std;struct Node {int datai;int dataj;Node* next; }; //棧 struct Stack {Node* pTop; //頂部指針Node* pBottom; //底部指針 }; void Init(Stack* pS);//初始化 //void CreateStack(Stack* pS);//建棧 void Push(Stack* pS, int vali, int valj);//壓棧 bool Pop(Stack* pS);//出棧:把棧頂的結點刪掉 bool getTop(Stack* pS, int& vali, int& valj);//獲得棧頂元素:但不刪除棧頂結點 bool isEmpty(Stack* pS);//判斷棧頂是否為空 int getSize(Stack* pS);//獲取棧的長度 void Travers(Stack* pS);//遍歷棧 int main() {Stack s;int i = 0, j = 0;//定義迷宮矩陣int a[10][10] = { 0,0,0,0,0,0,0,0,0,0,0,1,1,0,1,1,1,0,1,0,0,1,1,0,1,1,1,0,1,0,0,1,1,1,1,0,0,1,1,0,0,1,0,0,0,1,1,1,0,0,//第五行0,1,1,1,0,1,1,1,0,0,0,1,0,1,1,1,0,1,1,0,0,0,0,0,0,1,0,0,1,0,0,1,1,1,1,1,1,1,1,0,0,0,0,0,0,0,0,0,0,0, };//輸出矩陣/*for (i = 0; i < 10; i++) {for (j = 0; j < 10; j++) {cout << a0[i][j] << " ";//a0[i*columns+j]等價于a0[i][j]}cout << endl;}return 0;*/Init(&s);Push(&s, 1, 1);i = 1; j = 1;//起點//四個方向,從右開始順時針while (i != 8 || j != 8) {//四個方向,從右開始順時針if (a[i+1][j] == 0) {if (a[i][j + 1] == 0) {if (a[i - 1][j] == 0) {if (a[i][j - 1] == 0) {a[i][j] = 0; Pop(&s); getTop(&s, i, j);}else { j--; Push(&s, i, j); a[i][j] = 0;}}else { i--; Push(&s, i, j); a[i][j] = 0;}}else { j++; Push(&s, i, j); a[i][j] = 0;}}else { i++; Push(&s, i, j); a[i][j] = 0;}}// Travers(&s);//新建一個棧接受已壓好的棧用以逆序輸出棧Stack r;Init(&r);for (int n = 0; n < getSize(&s); i++){getTop(&s,i,j);Pop(&s);Push(&r, i, j);}Travers(&r);} //初始化void Init(Stack * pS){pS->pTop = new Node();if (pS->pTop == NULL) {cerr << "動態(tài)內存分配失敗!" << endl;exit(1);}pS->pBottom = pS->pTop;//頂部指針和底部指針指向同一個位置pS->pTop->next = NULL; } //建棧 /*void CreateStack(Stack* pS) {int val;cout << "請輸入各個元素值:" << endl;while (cin >> val && val != -1){Push(pS, val);} }*/ //壓棧 void Push(Stack* pS, int vali,int valj) {Node* newNode = new Node();//新建結點if (newNode == NULL) {cerr << "動態(tài)內存分配失敗" << endl;exit(1);}newNode->datai = vali;newNode->dataj = valj;newNode->next = pS->pTop;pS->pTop = newNode; } //遍歷棧 void Travers(Stack* pS) {Node* p = pS->pTop;while (p!=pS->pBottom){cout << '('<<p->datai + 1<<','<<p->dataj + 1 <<')'<< "—>";p = p->next;}cout << endl; } //判斷棧是否為空:通過比較棧頂和棧尾是否相等,如相等,說明為空 bool isEmpty(Stack* pS) {if (pS->pTop == pS->pBottom)return true;return false; } //出棧:把棧頂的結點刪掉 bool Pop(Stack* pS) {if (isEmpty(pS))return false;Node* r = pS->pTop;//暫存頂指針pS->pTop = r->next;//棧頂指針下移一個結點delete r;//釋放空間r = NULL;return true; } //獲取棧頂元素:但不刪除棧頂結點 bool getTop(Stack* pS, int& vali,int& valj) {if (isEmpty(pS))return false;vali = pS->pTop->datai;valj = pS->pTop->dataj;return true; } //獲取棧的長度 int getSize(Stack* pS) {int len = 0;Node* p = pS->pTop;while (p != pS->pBottom) {len++;p = p->next;}return len; }

總結

以上是生活随笔為你收集整理的c++:栈的基本操作+实例:迷宫求解的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 亚洲一级色 | 久久首页 | 欧美黄色一区二区三区 | 亚洲精品中文字幕 | 国产91丝袜在线播放九色 | av一区在线观看 | 欧美精品免费一区二区 | 亚洲va韩国va欧美va精品 | 国产日韩专区 | 国产黄色免费观看 | 国产自产21区 | 欧美日韩亚洲一区二区 | 美女午夜视频 | 三级精品在线观看 | 欧美一区二区最爽乱淫视频免费看 | 久久视频精品在线 | 国产又黄又爽又色 | 免费的黄色av | 国产欧美日韩专区发布 | 日韩簧片| 日韩欧美有码 | 亚洲精品久久久久av无码 | av资源免费看 | 奇米影视在线观看 | 草逼国产| 另类ts人妖一区二区三区 | 久久精视频 | 久久国产一 | 天堂在线v | 黄色一区二区三区 | 日韩污视频在线观看 | 顶级黄色片 | 日韩在线中文字幕 | 亚洲午夜激情视频 | 九草av | 免费成人美女女 | www.777奇米 | 久久久精品人妻一区二区三区色秀 | 精品免费 | 欧美男女交配 | 久久精品无码av | 国产精品无码免费播放 | 91插视频 | 黄色片在线免费观看视频 | 亚洲视频一区在线 | 色偷偷五月天 | 天天噜| 久久美利坚 | 伊人影院久久 | 婷婷色中文 | 精品久久毛片 | 日韩精品久久久久久久 | 91综合国产 | 黄色大片日本 | 欧美极品喷水 | 蜜乳av一区二区三区 | 亚洲热在线 | 亚洲草逼视频 | 日韩精品免费 | 丁香婷婷视频 | 欧美日韩在线观看视频 | 国产区视频在线 | 中文字幕精品一二三四五六七八 | 免费不卡的av | 一道本一区二区 | 丰满岳乱妇一区二区 | 劲爆欧美第一页 | 婷婷丁香五 | 欧美日韩亚洲激情 | 亚洲老女人| 韩日av片| 久久免费视频2 | 婷婷激情小说 | 亚洲色诱 | 亚洲成人久久久 | 欧美爱爱网 | 久久婷婷成人综合色 | 国产一区二区三区在线看 | 人妻夜夜爽天天爽 | 高清不卡一区二区三区 | av动漫在线免费观看 | 色综合久久88色综合天天免费 | 久久久国产成人一区二区三区 | 91岛国| 国产a线| 欧美日韩国产图片 | aaa一区二区三区 | 成人免费毛片东京热 | 精品国产三级 | 男人的天堂久久 | 日p视频在线观看 | 久久精品亚洲无码 | 91在线观看 | 可以在线观看的黄色 | 78m78成人免费网站 | 91精品在线看 | 四虎av影院| 欧美一级黄色录像 | 香蕉中文网|