zoukankan      html  css  js  c++  java
  • 小猴爬台阶问题

    小猴爬台阶问题:

        有一仅仅小猴非常顽皮,喜欢爬台阶,但因为小猴太小,所以它仅仅能一步爬1个或2个台阶。请计算该小猴全部可能的爬行路径。


    package shuai.study.steps;
    
    import java.util.ArrayList;
    import java.util.HashSet;
    import java.util.Iterator;
    import java.util.List;
    import java.util.Set;
    
    /**
     * @author shengshu
     * 
     */
    public class MonkeyCrawl {
    
    	// Get paths, which will be permutated
    	public static Set<String> getPathsSet(int steps) {
    		Set<String> pathsSet = new HashSet<String>();
    
    		for (int i = 0; i <= steps / 2; i++) {
    			int twoStepSum = i * 2;
    			int oneStepTimes = steps - twoStepSum;
    
    			StringBuffer pathStringBuffer = new StringBuffer();
    
    			for (int x = 0; x < oneStepTimes; x++) {
    				// "-" represent one step
    				pathStringBuffer.append("-");
    			}
    
    			for (int y = 0; y < i; y++) {
    				// "=" represent two steps
    				pathStringBuffer.append("=");
    			}
    
    			pathsSet.add(pathStringBuffer.toString());
    		}
    
    		return pathsSet;
    	}
    
    	// Permutate all possible paths
    	public static void permutatePaths(String path, List<String> list) {
    		if (path.length() == 1) {
    			for (int i = 0; i < list.size(); i++) {
    				System.out.print(list.get(i));
    			}
    
    			System.out.println(path);
    		} else {
    			int index[] = new int[path.length()];
    
    			for (int i = 0; i < index.length; i++) {
    				index[i] = path.indexOf(path.charAt(i));
    			}
    
    			for (int i = 0; i < path.length(); i++) {
    				String subPath = path.substring(1, path.length());
    
    				if (i == index[i]) {
    					list.add("" + path.charAt(0));
    
    					permutatePaths(subPath, list);
    
    					list.remove(list.size() - 1);
    				}
    
    				path = subPath + path.charAt(0);
    			}
    		}
    	}
    
    	public static void main(String[] args) {
    		// Set steps as 15, or others
    		Set<String> pathsSet = MonkeyCrawl.getPathsSet(15);
    
    		Iterator<String> iterator = pathsSet.iterator();
    		while (iterator.hasNext()) {
    			String path = iterator.next();
    			MonkeyCrawl.permutatePaths(path, new ArrayList<String>());
    		}
    	}
    
    }
    


  • 相关阅读:
    F#学习开篇(一)
    F#学习(二)
    认识“闭包”
    Silverlight显示控件换行的几种方式
    关于P问题、NP问题、NPC问题
    LINQ&EF任我行(二)LinQ to Object
    WPF中资源的引用方法
    Linq to EF 与Linq to Object 使用心得
    C#中如何用拼音模糊匹配汉字的首字母
    WPF获取应用程序路径方法,获取程序运行路径方法
  • 原文地址:https://www.cnblogs.com/hrhguanli/p/4049263.html
Copyright © 2011-2022 走看看