激情久久久_欧美视频区_成人av免费_不卡视频一二三区_欧美精品在欧美一区二区少妇_欧美一区二区三区的

服務器之家:專注于服務器技術及軟件下載分享
分類導航

PHP教程|ASP.NET教程|Java教程|ASP教程|編程技術|正則表達式|C/C++|IOS|C#|Swift|Android|VB|R語言|JavaScript|易語言|vb.net|

服務器之家 - 編程語言 - Java教程 - 高效的java版排列組合算法

高效的java版排列組合算法

2021-03-31 13:37wmj2003 Java教程

這篇文章主要為大家詳細介紹了高效的java版排列組合算法,具有一定的參考價值,感興趣的小伙伴們可以參考一下

本文實例為大家分享了java排列組合算法的具體代碼,供大家參考,具體內容如下

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
package BeanUtil;
import java.util.ArrayList;
import java.util.List;
import com.work.core.exception.OurException;
/**
 * 統計任三出現的最多的幾率的組合
 *
 * @author wangmingjie
 * @date 2009-1-1下午01:22:19
 */
public class Copy_2_of_StatisAnyThree {
// 組合算法 
//  本程序的思路是開一個數組,其下標表示1到m個數,數組元素的值為1表示其下標 
//  代表的數被選中,為0則沒選中。  
//  首先初始化,將數組前n個元素置1,表示第一個組合為前n個數。  
//  然后從左到右掃描數組元素值的“10”組合,找到第一個“10”組合后將其變為 
//  “01”組合,同時將其左邊的所有“1”全部移動到數組的最左端。  
//  當第一個“1”移動到數組的m-n的位置,即n個“1”全部移動到最右端時,就得 
//  到了最后一個組合。  
//  例如求5中選3的組合:  
//  1  1  1  0  0  //1,2,3  
//  1  1  0  1  0  //1,2,4  
//  1  0  1  1  0  //1,3,4  
//  0  1  1  1  0  //2,3,4  
//  1  1  0  0  1  //1,2,5  
//  1  0  1  0  1  //1,3,5  
//  0  1  1  0  1  //2,3,5  
//  1  0  0  1  1  //1,4,5  
//  0  1  0  1  1  //2,4,5  
//  0  0  1  1  1  //3,4,5 
  public static void main(String[] args) {
    Copy_2_of_StatisAnyThree s = new Copy_2_of_StatisAnyThree();
    s.printAnyThree();  
  }
  
  /**
   *
   */
  public void printAnyThree(){
    int[] num = new int[]{1,2,3,4,5,6};
    print(combine(num,3));
  }
  /**
   * 從n個數字中選擇m個數字
   * @param a
   * @param m
   * @return
   */
  public List combine(int[] a,int m){
    int n = a.length;
    if(m>n){
      throw new OurException("錯誤!數組a中只有"+n+"個元素。"+m+"大于"+2+"!!!");
    }
    
    List result = new ArrayList();
    
    int[] bs = new int[n];
    for(int i=0;i<n;i++){
      bs[i]=0;
    }
    //初始化
    for(int i=0;i<m;i++){
      bs[i]=1;
    }
    boolean flag = true;
    boolean tempFlag = false;
    int pos = 0;
    int sum = 0;
    //首先找到第一個10組合,然后變成01,同時將左邊所有的1移動到數組的最左邊
    do{
      sum = 0;
      pos = 0;
      tempFlag = true;
      result.add(print(bs,a,m));
      
      for(int i=0;i<n-1;i++){
        if(bs[i]==1 && bs[i+1]==0 ){
          bs[i]=0;
          bs[i+1]=1;
          pos = i;
          break;
        }
      }
      //將左邊的1全部移動到數組的最左邊
      
      for(int i=0;i<pos;i++){
        if(bs[i]==1){
          sum++;
        }
      }
      for(int i=0;i<pos;i++){
        if(i<sum){
          bs[i]=1;
        }else{
          bs[i]=0;
        }
      }
      
      //檢查是否所有的1都移動到了最右邊
      for(int i= n-m;i<n;i++){
        if(bs[i]==0){
          tempFlag = false;
          break;
        }
      }
      if(tempFlag==false){
        flag = true;
      }else{
        flag = false;
      }
      
    }while(flag);
    result.add(print(bs,a,m));
    
    return result;
  }
  
  private int[] print(int[] bs,int[] a,int m){
    int[] result = new int[m];
    int pos= 0;
    for(int i=0;i<bs.length;i++){
      if(bs[i]==1){
        result[pos]=a[i];
        pos++;
      }
    }
    return result ;
  }
  
  private void print(List l){
    for(int i=0;i<l.size();i++){
      int[] a = (int[])l.get(i);
      for(int j=0;j<a.length;j++){
        System.out.print(a[j]+"/t");
      }
      System.out.println();
    }
  }
}

以上就是本文的全部內容,希望對大家的學習有所幫助,也希望大家多多支持服務器之家。

原文鏈接:http://blog.csdn.net/wmj2003/article/details/3678941

延伸 · 閱讀

精彩推薦
  • Java教程Spring Cloud Gateway 如何修改HTTP響應信息

    Spring Cloud Gateway 如何修改HTTP響應信息

    這篇文章主要介紹了Spring Cloud Gateway 修改HTTP響應信息的方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教...

    帷幄庸者13712021-10-13
  • Java教程淺談java 中equals和==的區別

    淺談java 中equals和==的區別

    這篇文章主要介紹了java 中equals和==的區別,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小...

    獨特潤許多人5982021-07-21
  • Java教程二進制中1的個數

    二進制中1的個數

    這篇文章介紹了二進制中1的個數,有需要的朋友可以參考一下 ...

    java之家2662019-10-15
  • Java教程Spring 6.0 將停止支持 Freemarker 和 JSP

    Spring 6.0 將停止支持 Freemarker 和 JSP

    Spring Framework 6.0 第一個里程碑版本已經發布,目前已經可以從Spring Repo獲取。這里有一些新變更我們可以提前了解一下。...

    碼農小胖哥12642021-12-31
  • Java教程淺談sql_@SelectProvider及使用注意說明

    淺談sql_@SelectProvider及使用注意說明

    這篇文章主要介紹了sql_@SelectProvider及使用注意說明,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教...

    icecoola_6892021-11-04
  • Java教程Java開發常見異常及解決辦法詳解

    Java開發常見異常及解決辦法詳解

    這篇文章主要介紹了java程序常見異常及處理匯總,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友可以參考...

    cutercorley12252021-12-18
  • Java教程mybatis批量新增、刪除、查詢和修改方式

    mybatis批量新增、刪除、查詢和修改方式

    這篇文章主要介紹了mybatis批量新增、刪除、查詢和修改方式,具有很好的參考價值,希望對大家有所幫助。如有錯誤或未考慮完全的地方,望不吝賜教...

    xuforeverlove7492022-01-24
  • Java教程mybatis調用存儲過程的實例代碼

    mybatis調用存儲過程的實例代碼

    這篇文章主要介紹了mybatis調用存儲過程的實例,非常不錯,具有參考借鑒價值,需要的朋友可以參考下...

    動力節點11732021-01-25
主站蜘蛛池模板: 国产午夜精品一区二区三区免费 | 色妇视频| 精精国产xxxx视频在线野外 | 欧美a久久 | 国产亚洲欧美视频 | 99最新地址 | 草草视频免费 | 色综合网在线观看 | 亚洲亚色 | 免费啪啪| 成人性视频欧美一区二区三区 | 久久逼逼| 亚洲成人黄色片 | 91九色视频在线播放 | 亚洲视频在线一区二区 | 欧美一级性 | 九色91视频| 国产精品久久国产精品 | 99视频在线观看视频 | 青青草成人影视 | 一级α片| 久久亚洲一区二区三区成人国产 | 北原夏美av| 精品一区二区三区中文字幕老牛 | 国产一区二区三区精品在线观看 | 国产精品视频六区 | 国产1区在线观看 | 国产妇女乱码一区二区三区 | 免费在线性爱视频 | 日日摸夜夜添夜夜添牛牛 | 国产剧情在线观看一区二区 | 国产九九在线视频 | 成人毛片100部免费观看 | 亚洲成人入口 | 久久精品一区二区三区不卡牛牛 | av7777777| 欧美成人综合视频 | 国产69精品久久久久99尤 | 视频一区二区在线播放 | 欧美久久久久久久久 | 久久在线精品视频 |