青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品

逛奔的蝸牛

我不聰明,但我會很努力

   ::  :: 新隨筆 ::  ::  :: 管理 ::

/**

 * 求 N 個元素中 M 個元素的組合算法:

 * 1. 創建一個大小為 N 個元素的數組,前 M 個元素為1,后面的 N-M 個元素為0

 * 2. 從左向右找到 10 的元素(前一個元素是1,下一個元素是0), 交換這兩個元素;

 *    把此元素前面的所有1都移動到數組的最前面,此為一個組合,輸出.

 * 3. 直到前 N-M 個元素都為0,則結束,否則繼續第2步直到結束.

 */

public class Combinatory {

    public static void produceCombination(String str, int size) {

        if (size > str.length()) { throw new IllegalArgumentException("Size is to large."); }


        // 創建一個數組,前size個元素全是1

        int[] digit = new int[str.length()];

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

            digit[i] = 1;

        }


        // 輸出第一組

        printCombination(str, digit);


        while (!end(digit, digit.length - size)) {

            for (int i = 0; i < digit.length - 1; ++i) {

                if (digit[i] == 1 && digit[i + 1] == 0) {

                    // i上是1,i + 1是0,交換

                    int temp = digit[i];

                    digit[i] = digit[i + 1];

                    digit[i + 1] = temp;


                    // 移動i前面的所有1到最左端

                    int count = countOf1(digit, i);

                    for (int j = 0; j < count; ++j) {

                        digit[j] = 1;

                    }


                    for (int j = count; j < i; ++j) {

                        digit[j] = 0;

                    }


                    printCombination(str, digit);


                    break;

                }

            }

        }

    }


    // 在下標end前1的個數

    private static int countOf1(int[] digit, int end) {

        int count = 0;

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

            if (digit[i] == 1) {

                ++count;

            }

        }


        return count;

    }


    // 數組中為1的下標對應的字符需要輸出

    private static void printCombination(String str, int[] digit) {

        StringBuffer sb = new StringBuffer();

        for (int i = 0; i < digit.length; ++i) {

            if (digit[i] == 1) {

                sb.append(str.charAt(i));

            }

        }


        System.out.println(sb);

    }


    // 結束條件:前 size 個元素都是0

    private static boolean end(int[] digit, int size) {

        int sum = 0;


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

            sum += digit[i];

        }


        return sum == 0 ? true : false;

    }


    public static void main(String[] args) {

        Combinatory.produceCombination("0123456789", 8);

    }

}


===============================================


import java.util.HashSet;

import java.util.Set;


/**

 * 求 N 個元素的全排列算法:

 * 1. 創建一個大小為 N 個元素的數組.

 * 2. 利用 N 進制,滿 N 加 1的原則,對數組的第0個元素加 1,滿 N 了,則下一個元素值加 1.

 * 3. 檢查數組中的元素是否有重復的,如果沒有,則是一個排列.

 * 4. 直到數組中的元素為0, 1, 2, ..., N - 1,則結束,否則繼續第2步直到結束.

 */

public class Arrangement {

    public static void produceArrangement(String str) {

        int[] digit = new int[str.length()];

        int base = str.length();

        

        while (!end(digit)) {

            ++digit[0]; // 第1個元素值加1

            

            // 滿N進1

            for (int i = 0; i < digit.length; ++i) {

                if (digit[i] == base) {

                    digit[i] = 0;

                    ++digit[i + 1];

                } else {

                    break;

                }

            }

            

            if (isArrangement(digit)) {

                printArrangement(str, digit);

            }

        }

    }

    

    // 數組中每個元素都不同,則是排列中的一個

    private static boolean isArrangement(int[] digit) {

        int sum = 0;

        int endSum = (0 + digit.length - 1) * digit.length / 2;

        

        for (int i = 0; i < digit.length; ++i) {

            sum += digit[i];

        }

        

        // 為了減少創建Set,所以判斷一下數組中元素的和是不是結束時元素的和,如果是才再繼續判斷.

        if (sum != endSum) {

            return false;

        } else {

            Set<Integer> is = new HashSet<Integer>();

            for (int i : digit) {

                is.add(i);

            }

            

            if (is.size() != digit.length) {

                return false;

            } else {

                return true;

            }

        }

    }

    

    private static void printArrangement(String str, int[] digit) {

        StringBuilder sb = new StringBuilder();

        for (int i = 0; i < digit.length; ++i) {

            sb.append(str.charAt(digit[i]));

        }

        

        System.out.println(sb);

    }


    // 如果數組中的元素是 0, 1, 2, ..., digit.length - 1,則結束

    private static boolean end(int[] digit) {

        for (int i = 0; i < digit.length; ++i) {

            if (digit[i] != i) {

                return false;

            }

        }

        

        return true;

    }

    

    public static void main(String[] args) {

        Arrangement.produceArrangement("012345");

    }

}


===============================================

/**

 * 使用遞歸求組合

 * 找到第i個元素后面的count - 1個元素的組合

 */

import java.util.ArrayList;

import java.util.Arrays;

import java.util.Collection;

import java.util.Iterator;

import java.util.List;


public class IterativeCombinatory {

    private List result;

    private String data;


    public IterativeCombinatory(String data, int count) {

        this.data = data;

        this.result = new ArrayList();


        buildCombinatory(0, count);

    }


    // 使用遞歸求組合

    public void buildCombinatory(int index, int count) {

        for (int i = index; i < data.length(); i++) {

            result.add("" + data.charAt(i));


            if (1 == count) {

                System.out.println(StringUtil.join(result, "+"));

            } else if (i + 1 < data.length()) {

                buildCombinatory(i + 1, count - 1); // 在i后面找count-1個的組合

            }


            result.remove("" + data.charAt(i)); // 滿足一個后移除最后一個

        }

    }


    public static void main(String[] args) {

        String str = "123456";


        for (int count = 2; count <= str.length(); count++) {

            new IterativeCombinatory(str, count);

            System.out.println();

        }

    }

}


class StringUtil {

    public static String join(Object[] arr, String separator) {

        return join(Arrays.asList(arr), separator);

    }


    public static String join(Collection collection, String separator) {

        StringBuilder sb = new StringBuilder();

        separator = separator == null ? "" : separator;


        Iterator iter = collection.iterator();

        while (iter.hasNext()) {

            sb.append(iter.next());

            if (iter.hasNext()) {

                sb.append(separator);

            }

        }


        return sb.toString();

    }

}


 

posted on 2010-12-24 02:47 逛奔的蝸牛 閱讀(738) 評論(0)  編輯 收藏 引用 所屬分類: Java
青青草原综合久久大伊人导航_色综合久久天天综合_日日噜噜夜夜狠狠久久丁香五月_热久久这里只有精品
  • <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>
            一区二区欧美亚洲| 欧美91大片| 亚洲高清久久网| 欧美不卡高清| 免费成人黄色片| 亚洲国产精品高清久久久| 最新精品在线| 午夜精品久久久久久99热| 欧美亚洲在线| 老司机精品久久| 欧美肉体xxxx裸体137大胆| 国产精品白丝jk黑袜喷水| 国产网站欧美日韩免费精品在线观看 | 亚洲伦理在线免费看| 中文av一区二区| 久久精品一二三| 亚洲精品综合在线| 香蕉久久精品日日躁夜夜躁| 久久久久久亚洲精品中文字幕 | 欧美日韩亚洲精品内裤| 国产精品女主播| 伊人激情综合| 亚洲一级在线| 女女同性精品视频| 亚洲手机成人高清视频| 美国三级日本三级久久99| 国产精品免费看久久久香蕉| 尤物精品在线| 欧美一区二区三区在线看| 亚洲第一伊人| 欧美在线|欧美| 欧美日韩在线亚洲一区蜜芽| 一区二区在线观看av| 亚洲免费在线视频| 男女av一区三区二区色多| 亚洲精品国产精品国自产在线 | 亚洲一区二区伦理| 久久一区二区三区国产精品| 99伊人成综合| 美乳少妇欧美精品| 国产亚洲美州欧州综合国| 在线亚洲一区二区| 欧美成人高清| 久久久久国产精品厨房| 国产乱码精品一区二区三区不卡| 99视频在线精品国自产拍免费观看 | 欧美日韩精品一区二区三区四区| 在线精品视频一区二区| 久久高清福利视频| 亚洲欧美日韩国产一区二区| 欧美日韩中文字幕| 99精品久久久| 亚洲美女在线一区| 欧美日韩免费一区二区三区| 亚洲老板91色精品久久| 欧美高清视频一二三区| 麻豆视频一区二区| 亚洲国产aⅴ天堂久久| 欧美 日韩 国产 一区| 久久影视精品| 亚洲美女av网站| 99视频在线精品国自产拍免费观看| 欧美国产大片| 亚洲午夜在线观看视频在线| 一区二区三区高清| 国产精品一区免费在线观看| 午夜精品视频在线观看一区二区| 亚洲视频专区在线| 国产欧美一区二区精品婷婷 | 欧美一区二区三区免费视| 国产精品久久久久永久免费观看| 亚洲欧美视频一区| 欧美一区日本一区韩国一区| 黄色日韩网站| 亚洲国内自拍| 欧美视频在线观看一区| 午夜精品99久久免费| 午夜激情久久久| 亚洲国产一区二区精品专区| 亚洲精品看片| 国产精品视频导航| 久久男女视频| 一区二区在线免费观看| 蜜桃av噜噜一区二区三区| 久久黄金**| 亚洲欧洲精品成人久久奇米网| 亚洲精品国产精品久久清纯直播| 国产精品久久久久久超碰| 久久久久久9| 欧美成人资源| 性久久久久久久久| 蜜臀久久99精品久久久久久9| 亚洲一二三级电影| 久久久精品国产免费观看同学| 亚洲麻豆av| 午夜亚洲福利| 一本到12不卡视频在线dvd| 欧美伊人久久| 亚洲女女女同性video| 麻豆精品视频在线观看| 欧美一区二区三区视频在线| 欧美国产精品va在线观看| 性一交一乱一区二区洋洋av| 欧美成人黑人xx视频免费观看| 香蕉久久夜色| 欧美日韩免费网站| 欧美黄色免费网站| 国产午夜亚洲精品理论片色戒| 亚洲精品之草原avav久久| 伊人成人在线视频| 午夜日韩福利| 性欧美18~19sex高清播放| 农夫在线精品视频免费观看| 久久不射网站| 国产精品久久久久久影视| 亚洲国产精品电影在线观看| 狠狠色综合播放一区二区| 亚洲欧美激情在线视频| 亚洲一级黄色| 欧美日本在线| 亚洲国产精品激情在线观看| 激情五月综合色婷婷一区二区| 亚洲一区久久久| 亚洲欧美日韩国产一区二区| 欧美日韩成人免费| 最新成人在线| 亚洲精品久久久久久久久久久久久| 久久精品久久99精品久久| 久久国产精品色婷婷| 国产毛片精品视频| 欧美永久精品| 老牛影视一区二区三区| 国产综合欧美在线看| 久久久久久久欧美精品| 美玉足脚交一区二区三区图片| 狠狠久久五月精品中文字幕| 久久精品视频在线免费观看| 噜噜噜噜噜久久久久久91| 在线播放日韩| 欧美成人一区二免费视频软件| 亚洲国产成人一区| 亚洲深夜av| 国产欧美日韩精品在线| 性欧美xxxx大乳国产app| 久久成年人视频| 黄色成人av在线| 免费高清在线视频一区·| 亚洲国产成人精品久久| 亚洲午夜精品久久久久久app| 国产精品国产成人国产三级| 国产精品日本| 久久精品国产96久久久香蕉| 国产精品系列在线播放| 亚洲影视在线播放| 久久久久久久久伊人| 伊人久久亚洲美女图片| 蜜臀久久99精品久久久画质超高清| 欧美韩国一区| 亚洲在线播放电影| 国产日韩精品一区二区| 久久人人九九| 一本大道av伊人久久综合| 欧美中在线观看| 亚洲精品字幕| 国产午夜精品视频| 欧美国产精品一区| 亚洲欧美视频在线观看| 亚洲大胆av| 久久爱www.| 宅男精品视频| 1000部国产精品成人观看| 欧美日韩性视频在线| 欧美在线观看视频一区二区三区| 亚洲国产精品一区二区第四页av| 午夜精品久久久久99热蜜桃导演| 亚洲福利一区| 国产亚洲激情在线| 欧美日韩第一区日日骚| 久久精品国产精品| 一区二区欧美国产| 你懂的成人av| 久久国产精品72免费观看| 亚洲乱码国产乱码精品精| 国产精品专区h在线观看| 欧美激情第六页| 久久免费视频一区| 午夜久久久久| 一区二区三区 在线观看视频| 免费亚洲电影| 久久精品亚洲精品| 亚洲永久字幕| avtt综合网| 亚洲精品国精品久久99热一| 国内精品伊人久久久久av一坑| 欧美午夜精品理论片a级大开眼界| 美女露胸一区二区三区| 久久狠狠亚洲综合| 欧美一二区视频| 亚洲在线国产日韩欧美| 99精品久久|