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

歡迎訪問 生活随笔!

生活随笔

當(dāng)前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

c语言代码含义大全,小白求解代码各部分意思

發(fā)布時間:2025/3/8 编程问答 14 豆豆
生活随笔 收集整理的這篇文章主要介紹了 c语言代码含义大全,小白求解代码各部分意思 小編覺得挺不錯的,現(xiàn)在分享給大家,幫大家做個參考.

該樓層疑似違規(guī)已被系統(tǒng)折疊?隱藏此樓查看此樓

using namespace std;

typedef struct {

int x;

int y;

}Point;//表示一迷宮坐標(biāo)

void FindWay(int *path,int n,int m,Point start,Point end) {

while(start.x!=end.x || start.y!=end.y) {

cout<

switch(path[start.x*(m+1)+start.y]) {

case 0:start.x--; break;

case 1:start.x--; start.y++; break;

case 2:start.y++; break;

case 3: start.x++; start.y++; break;

case 4: start.x++; break;

case 5:start.x--; start.y--; break;

case 6: start.y--; break;

case 7:start.y--; break;

default: cout<

}

}

cout<

return ;

}

void showAll(int *path,int n,int m)

{

for(int i=1;i<=n;++i) {

for(int j=1;j<=m;j++) {

switch(path[i*(m+1)+j]) {

case 0:cout<

case 1:cout<

case 2:cout<

case 3: cout<

case 4: cout<

case 5:cout<

case 6: cout<

case 7:cout<

default :cout<

}

}

cout<

}

}

class TravelMaze {

private:

Point start,end;

//Point current_point;

int best_num_turn; //最少轉(zhuǎn)向次數(shù)

int num_traved;//記錄經(jīng)過多少房間

int curr_num_turn;//當(dāng)前轉(zhuǎn)向次數(shù)

int *TX ;

int *TY ;

int n,m;

int b; //不可進(jìn)房間數(shù)

bool *maze;//迷宮

int *curr_path;//當(dāng)前解該點(diǎn)下一步走向 0-7 順時針

int *best_path;//最優(yōu)解的該點(diǎn)下一步走向 0-7 順時針

private:

bool IsOK(Point current_point)

{

//是否到達(dá)并且最少轉(zhuǎn)向最優(yōu)

if(num_traved==n*m-b &&

current_point.x==end.x && current_point.y==end.y)

if(curr_num_turn

return true;

return false;

}

void BackTrack(Point current_point,int dir)

{

if(IsOK(current_point)) {

curr_path[current_point.x*(m+1)+current_point.y] = -1;

for(int i=1; i<=n; ++i)

for(int j=1; j<=m; ++j) {

best_path[i*(m+1)+j] =curr_path[i*(m+1)+j];

best_num_turn=curr_num_turn;

}

return;

}

if(current_point.x == end.x && current_point.y == end.y)

return ;

bool flag = true;

Point tmp;

for(int i=0; i<=7; ++i) {

curr_path[current_point.x*(m+1)+current_point.y] = i;

tmp.x = current_point.x + TX[i];

tmp.y = current_point.y + TY[i];

//是否在迷宮內(nèi)

if(tmp.x<=0 || tmp.y<=0 || tmp.x>n || tmp.y>m)

continue;

//是否已經(jīng)經(jīng)過

if(!maze[tmp.x*(m+1)+tmp.y]) {

maze[tmp.x*(m+1)+tmp.y] = true;

if(i!=dir) ++curr_num_turn; //是否轉(zhuǎn)向

++num_traved;

BackTrack(tmp,i);

--num_traved;

if(i!=dir) --curr_num_turn;

//curr_path[current_point.x*(m+1)+current_point.y] = -1;

maze[tmp.x*(m+1)+tmp.y] = false;

}

}

}

public:

int Solve(int n_,int m_,Point bb[],int b_,Point start_,Point end_,int *path)

{

n = n_;//n行

m = m_;//m 列

b = b_;//不可進(jìn)房間數(shù)

start = start_;//開式位置

end = end_;//結(jié)束位置

best_num_turn = n*m+1; //最少轉(zhuǎn)向次數(shù)

num_traved = 1;//記錄經(jīng)過多少房間

curr_num_turn = 0;

maze = new bool [(n+1)*(m+1)];

for(int i=1;i<=n;i++)

for(int j=1;j<=m;++j)

maze[i*(m+1)+j] = false;

curr_path = new int [(n+1)*(m+1)];

best_path = path;

TX = new int[8];

TY = new int[8];

int tx[] = {-1,-1,0,1,1,1,0,-1};

int ty[] = {0,1,1,1,0,-1,-1,-1};

for(int i=0;i<=7;++i) {

TX[i]=tx[i];

TY[i]=ty[i];

}

for(int i=0;i

curr_path[bb[i].x*(m+1)+bb[i].y] = -1;

maze[bb[i].x*(m+1)+bb[i].y] = true;

}

maze[start.x*(m+1)+start.y] = true;

BackTrack(start_,-1);

delete[] TX;

delete[] TY;

delete[] maze;

delete[] curr_path;

return best_num_turn;

}

};

int main()

{

int n = 3,m=3;

Point a[4];

a[0].x = 1;a[0].y = 2;

a[1].x = 3;a[1].y = 7;

a[2].x = 5;a[2].y = 5;

a[3].x = 8;a[3].y = 2;

int path[(n+1)*(m+1)];

Point start,end;

start.x = start.y = 1;

end.x = end.y = 3;

TravelMaze tm;

int least=tm.Solve(n,m,a,1,start,end,path);

cout<

//FindWay(path,n,m,start,end);

showAll(path,n,m);

cin.get();

return 0;

}

總結(jié)

以上是生活随笔為你收集整理的c语言代码含义大全,小白求解代码各部分意思的全部內(nèi)容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網(wǎng)站內(nèi)容還不錯,歡迎將生活随笔推薦給好友。

主站蜘蛛池模板: 日本欧美一级片 | 亚洲欧美在线一区二区 | 国产精品美女一区二区三区 | 国产精品69久久 | 黄色av资源| 久草久 | 国产日韩欧美在线观看 | 亚洲手机视频 | www.久久av.com | 日本中文字幕成人 | 强侵犯の奶水授乳羞羞漫虐 | 国产成人精品一二三区 | 精品视频一区二区三区在线观看 | 狠狠人妻久久久久久综合 | 大尺度做爰啪啪床戏 | 尤物国产在线 | 国产日韩亚洲 | 久久婷婷一区 | 欧美精品一区二区三区在线播放 | 超碰中文字幕 | www.啪啪| 99久久精品国产毛片 | 久久大香| 国产五月天婷婷 | 99久久久无码国产精品性 | 欧美精品一区在线 | 中国美女洗澡免费看网站 | 久久精品观看 | 福利一区三区 | 欧美特级黄 | 一级黄色免费观看 | 国产裸体网站 | 91社区在线播放 | 午夜日韩视频 | 国产第113页 | 欧美爱爱免费视频 | 日本乱子伦| 国产你懂| 国产精品交换 | 午夜性色| 日韩欧美在线看 | 日本黄色美女网站 | 久久不卡日韩美女 | 欧美日韩一级二级 | 日韩精品激情 | 午夜精品久久久久久久久久 | 丰满少妇高潮久久三区 | 欧美高清在线一区 | 欧美被狂躁喷白浆精品 | 日本一级免费视频 | 欧美精品一区二区蜜臀亚洲 | 在线免费观看黄色小视频 | 国产清纯白嫩初高中在线观看性色 | 波多野结衣办公室33分钟 | 欧美日韩激情在线一区二区三区 | 图书馆的女友动漫在线观看 | 爱爱网站视频 | 黄色精品网站 | 亚洲欧美综合一区 | 91视频免费视频 | 日韩精品在线免费观看视频 | 爱爱视频在线免费观看 | 精品视频91| 日本在线观看网站 | 亚洲无人区码一码二码三码 | 欧美亚洲在线播放 | 日韩av在线免费 | 日本美女性高潮 | 美女扒开腿男人爽桶 | 尤物最新网址 | 国产人妻aⅴ色偷 | 久久99精品久久久久久国产越南 | 亚洲免费精品视频 | 中文字幕天堂 | 久久精品无码中文字幕 | 青青青网| 不用播放器看av | 欧美熟妇精品久久久久久 | 欧美群妇大交乱 | 天天操天天射天天舔 | 欧美一区二区三区四区视频 | 日韩精品91 | 亚洲欧美日韩高清 | 精品日韩一区 | 中文在线观看免费视频 | 一区二区三区麻豆 | 精品国产一区二区视频 | 极品人妻一区二区三区 | 综合国产在线 | 黑人黄色录像 | 韩日少妇 | 九色porny视频 | 国产伦精品一区二区三区视频痴汉 | 影音先锋波多野结衣 | 中文字幕一区二区精品 | 欧美特黄一区二区三区 | 懂色av一区二区三区 | japanese24hdxxxx日韩| 亚洲欧美综合自拍 |