青蛙过河是一个非常有趣的智力游戏,其大意如下: 一条河之间有若干个石块间隔,有两队青蛙在过河,每队有3只青蛙,这些青蛙只能向前移动,不能向后移动,且一次只能有一只青蛙向前移动。在移动过程中,青蛙可以向前面的空位中移动,不可以一次跳过两个位置,但是可以跳过对方一只青蛙进入到前面的一个空位。问两队青蛙该如何移动才能用最少的步数分别走向对岸?( → → → □ ← ← ← )可能3只青蛙太少了,心算也不难。如果有100只青蛙呢?

/**
* 青蛙过河
* @author rubekid
*
*/
public class RiverFrog { public static final int LEFT_FROG = -1; public static final int RIGHT_FROG = 1; public static final int STONE = 0; private int[] frogs; private int zeroIndex; private int length; private int step = 0; public RiverFrog(int number) {
frogs = new int[number * 2 +1];
length = frogs.length;
zeroIndex = length /2;
for(int i=0; i< number; i++){
frogs[i] = LEFT_FROG;
}
frogs[zeroIndex] = STONE;
for(int i=0; i< number; i++){
frogs[i+ zeroIndex + 1] = RIGHT_FROG;
} } public void run(){ while(!isMoveEnd(LEFT_FROG) || !isMoveEnd(RIGHT_FROG)){
int left = zeroIndex - 1;
int right = zeroIndex+1; if(left>-1 && right <length){
if(frogs[left] != frogs[right]){
if(frogs[left] == LEFT_FROG){
if(left > 0 && frogs[left-1] == RIGHT_FROG){//若移动right,则在中间有两只RIGHT并排
this.move(right);
}
else{
this.move(left);
}
}
else if(left > 0 && frogs[left-1]==LEFT_FROG ){
this.move(left-1);
}
else if(right <= length && frogs[right+1] == RIGHT_FROG){
this.move(right+1);
}
}
else{
if(frogs[left] == RIGHT_FROG){
if(left > 0 && frogs[left-1] == LEFT_FROG){
this.move(left - 1);
}
else if(right+1 < length && frogs[right+1] == RIGHT_FROG){
this.move(right+1);
}
else if(frogs[right] == RIGHT_FROG){
this.move(right);
}
}
else if(frogs[right] == LEFT_FROG){
if(right+1 < length && frogs[right+1] == RIGHT_FROG){
this.move(right + 1);
}
else if(left >0 && frogs[left-1] == LEFT_FROG){
this.move(left-1);
}
else if(frogs[left] == LEFT_FROG){
this.move(left);
}
}
}
}
else if(left == -1){
if(frogs[right] == LEFT_FROG && right<length-1){
this.move(right+1);
}
else{
this.move(right);
}
}
else if(right == length){
if(frogs[left] == RIGHT_FROG && left > 0){
this.move(left-1);
}
else{
this.move(left);
}
}
}
System.out.println("step:" + step);
} private void move(int i){
int temp = frogs[i];
frogs[i] = frogs[zeroIndex];
frogs[zeroIndex] = temp;
zeroIndex = i;
step++;
print();
} private boolean isMoveEnd(int value){
int i=0; int max= zeroIndex;
if(value == LEFT_FROG){
i = zeroIndex+1;
max = length;
}
for(int j=i; j<max; j++){
if(frogs[j]!=value){
return false;
}
}
return true;
} private void print(){
StringBuffer stringBuffer = new StringBuffer();
for(int frog : frogs){
if(frog>-1){
stringBuffer.append(" " +frog + " ");
}
else{
stringBuffer.append(frog + " ");
} }
System.out.println(stringBuffer.toString());
}
}

趣味算法——青蛙过河(JAVA)的更多相关文章

  1. Java实现 LeetCode 403 青蛙过河

    403. 青蛙过河 一只青蛙想要过河. 假定河流被等分为 x 个单元格,并且在每一个单元格内都有可能放有一石子(也有可能没有). 青蛙可以跳上石头,但是不可以跳入水中. 给定石子的位置列表(用单元格序 ...

  2. [LeetCode] Frog Jump 青蛙过河

    A frog is crossing a river. The river is divided into x units and at each unit there may or may not ...

  3. NOIP 2005 青蛙过河

    做题记录:2016-08-10 21:58:09 题目描述 在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都 ...

  4. ooj 1066 青蛙过河DP

    http://121.249.217.157/JudgeOnline/problem.php?id=1066 1066: 青蛙过河 时间限制: 1 Sec  内存限制: 64 MB提交: 58  解决 ...

  5. HRBUST 1186 青蛙过河 (思路错了)

    在河上有一座独木桥,一只青蛙想沿着独木桥从河的一侧跳到另一侧.在桥上有一些石子,青蛙很讨厌踩在这些石子上.由于桥的长度和青蛙一次跳过的距离都是正整数,我们可以把独木桥上青蛙可能到达的点看成数轴上的一串 ...

  6. P1244 青蛙过河

    P1244 青蛙过河NOI2000主要思想:数学归纳法 递推 压位高精度 化归 理解能力和找规律的能力题意再述:1.青蛙从上到下必须连续递增或者下面是石墩 而不能是1 12 33 4而且每时每刻都要满 ...

  7. Dijkstra算法求最短路径(java)(转)

    原文链接:Dijkstra算法求最短路径(java) 任务描述:在一个无向图中,获取起始节点到所有其他节点的最短路径描述 Dijkstra(迪杰斯特拉)算法是典型的最短路径路由算法,用于计算一个节点到 ...

  8. 排序算法总结(基于Java实现)

    前言 下面会讲到一些简单的排序算法(均基于java实现),并给出实现和效率分析. 使用的基类如下: 注意:抽象函数应为public的,我就不改代码了 public abstract class Sor ...

  9. 常见排序算法题(java版)

    常见排序算法题(java版) //插入排序:   package org.rut.util.algorithm.support;   import org.rut.util.algorithm.Sor ...

随机推荐

  1. mysql报Fatal error encountered during command execution的解决办法

    连接字符串里加上 Allow User Variables=True 解决. 否则时不时的报错,存储过程名长一点也报错,又有时报有时不报,参数传1位数就正常2位数就报错等…… 折腾mysql蛋疼啊

  2. js移动设备手机跳转地址代码

    if(/AppleWebKit.*mobile/i.test(navigator.userAgent) || (/MIDP|SymbianOS|NOKIA|SAMSUNG|LG|NEC|TCL|Alc ...

  3. mysql的sql优化案例

    前言 mysql的sql优化器比较弱,选择执行计划貌似很随机. 案例 一.表结构说明mysql> show create table table_order\G***************** ...

  4. 30 个 php 操作 redis 常用方法代码例子

    这篇文章主要介绍了 30 个 php 操作 redis 常用方法代码例子 , 本文其实不止 30 个方法 , 可以操作 string 类型. list 类型和 set 类型的数据 , 需要的朋友可以参 ...

  5. split和join和pop和remove用法

    简单字符串分割不需要import re,多字符串分割要导入re,多个字符串分割的分隔符要用 | 分开 >>> msg='chen hang wuhan keji daxue aljl ...

  6. 转:PHP include()和require()方法的区别

    文章来自于:http://developer.51cto.com/art/200909/153687.htm 本文总结了PHP的include()和require()两种包含外部文件的方法的不同之处. ...

  7. Node.js 安装 初体验(1)

    1.安装nodejs http://nodejs.org/download/  自动根据系统下载自己的版本node.js 2.环境变量 windows 安装,不需要配置环境变量   mac安装后,会提 ...

  8. windows下bat批处理实现守护进程(有日志)

    开发部的一个核心程序总是会自己宕机,然后需要手工去起,而这个服务的安全级别又很高,只有我可以操作,搞得我晚上老没法睡,昨晚实在受不了了,想起以前在hp-ux下写的shell守护进程,这回搞个windo ...

  9. android 程序中res/values-v14/styles.xml报错的解决办法

    从旧的ADT迁移的新的ADT时, android 程序中res/values-v14/styles.xml报错: error: Error retrieving parent for item: No ...

  10. BZOJ1708: [Usaco2007 Oct]Money奶牛的硬币

    1708: [Usaco2007 Oct]Money奶牛的硬币 Time Limit: 5 Sec  Memory Limit: 64 MBSubmit: 513  Solved: 329[Submi ...