Java簡單實(shí)現(xiàn)農(nóng)夫過河問題示例
本文實(shí)例講述了Java簡單實(shí)現(xiàn)農(nóng)夫過河問題。分享給大家供大家參考,具體如下:
一、問題描述
老伯伯要帶魚、狗、貓過河到對岸.,有一條船,只能坐一個人,老伯每次只能帶一樣動物過河,當(dāng)老伯不在的時侯狗會咬貓,貓會吃魚.,請問怎么順序過河呢?
二、實(shí)現(xiàn)代碼
package demo; import java.util.ArrayList; import java.util.List; public class CrossRiver { List<String> listThis = new ArrayList<String>(); List<String> listThat = new ArrayList<String>(); /*boolean thisFlag = true; boolean thatFlag = false; */ public CrossRiver() { listThis.add("dog"); listThis.add("fish"); listThis.add("cat"); // listThis.add("people"); } public boolean isSafe(@SuppressWarnings("rawtypes") List list){ if(list.contains("fish")&&list.contains("cat")||list.contains("cat")&&list.contains("dog")){ return false; }else{ return true; } } public void thisTothat(){ String str = listThis.get(0); listThis.remove(str); if(this.isSafe(listThis)){ System.out.println("農(nóng)夫帶著 " + str + " 從此岸到彼岸"); System.out.println("此岸" + listThis + "\b" + "彼岸" + listThat); System.out.println(); listThat.add(str); thatToThis(); }else{ listThis.add(str); thisTothat(); } } public void thatToThis(){ if(listThis.isEmpty()){ System.out.println("此岸" + listThis + "\b" + "彼岸" + listThat); return; } if(isSafe(listThat)){ System.out.println("農(nóng)夫從彼岸到此岸"); System.out.println("此岸" + listThis + "\b" + "彼岸" + listThat); System.out.println(); thisTothat(); }else{ String str = listThat.get(0); listThat.remove(0); if(isSafe(listThat)){ System.out.println("農(nóng)夫帶著 " + str + " 從彼岸到此岸"); System.out.println("此岸" + listThis + "\b" + "彼岸" + listThat); System.out.println(); listThis.add(str); thisTothat(); }else{ listThat.add(str); thatToThis(); } } } public static void main(String[] args){ System.out.println("腳本之家測試結(jié)果:"); System.out.println(); new CrossRiver().thisTothat(); } }
運(yùn)行結(jié)果:
更多關(guān)于java算法相關(guān)內(nèi)容感興趣的讀者可查看本站專題:《Java數(shù)據(jù)結(jié)構(gòu)與算法教程》、《Java操作DOM節(jié)點(diǎn)技巧總結(jié)》、《Java文件與目錄操作技巧匯總》和《Java緩存操作技巧匯總》
希望本文所述對大家java程序設(shè)計有所幫助。
- C++基于人工智能搜索策略解決農(nóng)夫過河問題示例
- 基于C++的農(nóng)夫過河問題算法設(shè)計與實(shí)現(xiàn)方法
- Java遞歸算法經(jīng)典實(shí)例(經(jīng)典兔子問題)
- Java實(shí)現(xiàn)的猴子吃桃問題算法示例
- Java數(shù)據(jù)結(jié)構(gòu)及算法實(shí)例:漢諾塔問題 Hanoi
- Java基于循環(huán)遞歸回溯實(shí)現(xiàn)八皇后問題算法示例
- 淺談java實(shí)現(xiàn)背包算法(0-1背包問題)
- Java矩陣連乘問題(動態(tài)規(guī)劃)算法實(shí)例分析
- Java算法之最長公共子序列問題(LCS)實(shí)例分析
- Java基于遞歸解決全排列問題算法示例
- Java基于分治算法實(shí)現(xiàn)的棋盤覆蓋問題示例
相關(guān)文章
Java List轉(zhuǎn)換成String數(shù)組幾種實(shí)現(xiàn)方式詳解
這篇文章主要介紹了Java List轉(zhuǎn)換成String數(shù)組幾種實(shí)現(xiàn)方式詳解的相關(guān)資料,需要的朋友可以參考下2016-12-12WebSocket實(shí)現(xiàn)數(shù)據(jù)庫更新時前端頁面刷新
這篇文章主要為大家詳細(xì)介紹了WebSocket實(shí)現(xiàn)數(shù)據(jù)庫更新時前端頁面刷新,具有一定的參考價值,感興趣的小伙伴們可以參考一下2019-04-04關(guān)于springBoot yml文件的list讀取問題總結(jié)(親測)
這篇文章主要介紹了關(guān)于springBoot yml文件的list讀取問題總結(jié),具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教2021-12-12JavaWeb實(shí)現(xiàn)文件上傳與下載實(shí)例詳解
在Web應(yīng)用程序開發(fā)中,文件上傳與下載功能是非常常用的功能,下面通過本文給大家介紹JavaWeb實(shí)現(xiàn)文件上傳與下載實(shí)例詳解,對javaweb文件上傳下載相關(guān)知識感興趣的朋友一起學(xué)習(xí)吧2016-02-02