<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
馬踏棋盤,用1枚馬走遍棋盤。我用一個二維陣列記錄模擬的整個路徑,x為列,y為行,以順時針的方式尋找下一格,演演算法比較簡單,就通過遞迴和迴圈回溯即可,就是如果是8*8的陣列,最壞可能執行8^(x*y)次,耗時長到懷疑人生。
#include<iostream> #define X 5 #define Y 5 void ShowResult(); using namespace std; int chess[Y][X]={ 0 }; int counter=0; int Next(int* x,int* y,int where){ switch(where){ case 0: if(*x+1<X&&*y-2>=0&&chess[*y-2][*x+1]==0){ *x+=1; *y-=2; return 1; } break; case 1: if(*x+2<X&&*y-1>=0&&chess[*y-1][*x+2]==0){ *x+=2; *y-=1; return 1; } break; case 2: if(*x+2<X&&*y+1<Y&&chess[*y+1][*x+2]==0){ *x+=2; *y+=1; return 1; } break; case 3: if(*x+1<X&&*y+2<Y&&chess[*y+2][*x+1]==0){ *x+=1; *y+=2; return 1; } break; case 4: if(*x-1>=0&&*y+2<Y&&chess[*y+2][*x-1]==0){ *x-=1; *y+=2; return 1; } break; case 5: if(*x-2>=0&&*y+1<Y&&chess[*y+1][*x-2]==0){ *x-=2; *y+=1; return 1; } break; case 6: if(*x-2>=0&&*y-1>=0&&chess[*y-1][*x-2]==0){ *x-=2; *y-=1; return 1; } break; case 7: if(*x-1>=0&&*y-2>=0&&chess[*y-2][*x-1]==0){ *x-=1; *y-=2; return 1; } break; } return 0; } int Explore(int x,int y){ int x1=x; int y1=y; int flag; int where=0; counter++; chess[y][x]=counter; if(counter==X*Y){ return 1; } flag=Next(&x1,&y1,where); while(flag==0&&where<7){ where++; flag=Next(&x1,&y1,where); } while(flag){ if(Explore(x1,y1)==1){ return 1; } else{ x1=x; y1=y; where++; flag=Next(&x1,&y1,where); while(flag==0&&where<7){ where++; flag=Next(&x1,&y1,where); } } } if(flag==0){ chess[y][x]=0; counter--; } return 0; } void ShowResult(){ for(int i=0;i<Y;i++){ for(int j=0;j<X;j++){ cout.width(4); cout<<chess[i][j]<<' '; } cout<<endl; } cout<<endl; } int main(){ int start=clock(); int result=Explore(2,1); int end=clock(); if(result){ ShowResult(); } else{ cout<<"have no path!"<<endl; } cout<<"spend time:"<<(end-start)/CLOCKS_PER_SEC<<" s"<<endl; return 0; }
以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支援it145.com。
相關文章
<em>Mac</em>Book项目 2009年学校开始实施<em>Mac</em>Book项目,所有师生配备一本<em>Mac</em>Book,并同步更新了校园无线网络。学校每周进行电脑技术更新,每月发送技术支持资料,极大改变了教学及学习方式。因此2011
2021-06-01 09:32:01
综合看Anker超能充系列的性价比很高,并且与不仅和iPhone12/苹果<em>Mac</em>Book很配,而且适合多设备充电需求的日常使用或差旅场景,不管是安卓还是Switch同样也能用得上它,希望这次分享能给准备购入充电器的小伙伴们有所
2021-06-01 09:31:42
除了L4WUDU与吴亦凡已经多次共事,成为了明面上的厂牌成员,吴亦凡还曾带领20XXCLUB全队参加2020年的一场音乐节,这也是20XXCLUB首次全员合照,王嗣尧Turbo、陈彦希Regi、<em>Mac</em> Ova Seas、林渝植等人全部出场。然而让
2021-06-01 09:31:34
目前应用IPFS的机构:1 谷歌<em>浏览器</em>支持IPFS分布式协议 2 万维网 (历史档案博物馆)数据库 3 火狐<em>浏览器</em>支持 IPFS分布式协议 4 EOS 等数字货币数据存储 5 美国国会图书馆,历史资料永久保存在 IPFS 6 加
2021-06-01 09:31:24
开拓者的车机是兼容苹果和<em>安卓</em>,虽然我不怎么用,但确实兼顾了我家人的很多需求:副驾的门板还配有解锁开关,有的时候老婆开车,下车的时候偶尔会忘记解锁,我在副驾驶可以自己开门:第二排设计很好,不仅配置了一个很大的
2021-06-01 09:30:48
不仅是<em>安卓</em>手机,苹果手机的降价力度也是前所未有了,iPhone12也“跳水价”了,发布价是6799元,如今已经跌至5308元,降价幅度超过1400元,最新定价确认了。iPhone12是苹果首款5G手机,同时也是全球首款5nm芯片的智能机,它
2021-06-01 09:30:45