国产片侵犯亲女视频播放_亚洲精品二区_在线免费国产视频_欧美精品一区二区三区在线_少妇久久久_在线观看av不卡

服務(wù)器之家:專注于服務(wù)器技術(shù)及軟件下載分享
分類導(dǎo)航

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

服務(wù)器之家 - 編程語言 - Java教程 - Java 得到集合中所有子集

Java 得到集合中所有子集

2020-08-05 11:21星火燎原智勇 Java教程

本文主要介紹了Java 得到集合中所有子集的方法。具有很好的參考價值,下面跟著小編一起來看下吧

面試中有一道筆試題,大概意思如下:

輸入一個集合,輸出這個集合的所有子集。例如輸入:1,2,4  輸出結(jié)果如下所示:

[1]
[2]
[4]
[1, 2]
[1, 4]
[2, 4]
[1, 2, 4]

需要認識的:空集是任何集合的子集;真子集為不包含子集的集合;非空真子集即不包含子集與空集合

解題思路:

這道題可以使用“按位對應(yīng)法”進行計算

如集合A={a,b,c},對于任意一個元素,在每個子集中,要么存在,要么不存在。 映射為子集:

(a,b,c)
(1,1,1)->(a,b,c)
(1,1,0)->(a,b)
(1,0,1)->(a,c)
(1,0,0)->(a)
(0,1,1)->(b,c)
(0,1,0)->(b)
(0,0,1)->(c)
(0,0,0)->@(@表示空集)

觀察以上規(guī)律,與計算機中數(shù)據(jù)存儲方式相似,故可以通過一個整型數(shù)與集合映射...000 ~ 111...111(表示有,表示無,反之亦可),通過該整型數(shù)逐次增可遍歷獲取所有的數(shù),即獲取集合的相應(yīng)子集。

主要考察的是位移運算以及邏輯思維能力,具體代碼如下(經(jīng)過本機真實認證,絕對可靠):

?
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
import java.util.ArrayList;
import java.util.Scanner;
import org.apache.commons.collections.CollectionUtils;
/**
 * 輸入一個集合,輸出這個集合的所有子集
 * @author liangyongxing
 * @time 2017-02-06
 */
public class SubListExport {
 public static void main(String[] args) {
  ArrayList<Integer> list = new ArrayList<Integer>();
  System.out.println("請輸入一串整數(shù)并在輸入時用英文逗號隔開:");
  String inputString = new Scanner(System.in).next().toString();
  if (inputString != null && !inputString.isEmpty()) {
   String[] strArray = inputString.split(",");
   for (String str : strArray) {
    list.add(Integer.parseInt(str));
   }
   ArrayList<ArrayList<Integer>> allsubsets = getSubsets(list);
   for(ArrayList<Integer> subList : allsubsets) {
    System.out.println(subList);
   }
  }
 }
 public static ArrayList<ArrayList<Integer>> getSubsets(ArrayList<Integer> subList) {
  ArrayList<ArrayList<Integer>> allsubsets = new ArrayList<ArrayList<Integer>>();
  int max = 1 << subList.size();
  for(int loop = 0; loop < max; loop++) {
   int index = 0;
   int temp = loop;
   ArrayList<Integer> currentCharList = new ArrayList<Integer>();
   while(temp > 0) {
    if((temp & 1) > 0) {
     currentCharList.add(subList.get(index));
    }
    temp>>=1;
    index++;
   }42    allsubsets.add(currentCharList);44   }
  return allsubsets;
 }
}

注:2017-02-08 10:01:32  上述代碼有一定的漏洞即當輸入有重復(fù)數(shù)字的時候,結(jié)果會有重復(fù)子集輸出,并不能滿足題目要求,需要在算出子集的時候加入HashSet進行排重,最終打印結(jié)果從sets中獲取即可,具體修改詳情如下圖所示:

1. 在主函數(shù)打印的地方修改接受的返回值為HashSet類型

Java 得到集合中所有子集

2. 在函數(shù)部分需要修改封裝列表有l(wèi)ist改為set

Java 得到集合中所有子集

至此修改完成,測試運行結(jié)果如下所示:

Java 得到集合中所有子集

分析代碼可以得出它的時間復(fù)雜度是:O(n*log2n)

代碼下載地址:

https://github.com/liang68/interview

以上就是本文的全部內(nèi)容,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作能帶來一定的幫助,同時也希望多多支持服務(wù)器之家!

原文鏈接:http://www.cnblogs.com/liang1101/p/6372115.html

延伸 · 閱讀

精彩推薦
主站蜘蛛池模板: 日韩免费在线 | 国产一区二区三区在线视频 | 国产精品爱久久久久久久 | 久久国产99 | 毛片xxx | 91久久精品视频 | 国产精品免费一区二区三区四区 | 亚洲欧洲精品成人久久奇米网 | 久久精品美女 | 久久久久久国产精品 | 激情在线观看视频 | 精品在线一区 | 亚洲在线日韩 | 青青国产视频 | 国产精品一区电影 | 国产高清av在线一区二区三区 | 深夜免费网站 | 自拍在线 | 中文字幕国产视频 | av7777| 一级黄片毛片 | 精品一二三四区 | 亚洲理论电影 | 中字精品 | 国产精品成人在线观看 | 午夜免费视频 | 国产色秀视频在线观看 | 国产免费黄色 | 久久亚洲欧美日韩精品专区 | 婷婷欧美 | 亚洲视频三区 | 国产女爽爽视频精品免费 | 日韩欧美一二三 | 国产亚洲精品一区二区 | 亚洲精品久久久久久一区二区 | 亚洲精品成人悠悠色影视 | 欧美黄色一级片免费看 | 久久综合久久综合久久综合 | 成人看的免费视频 | 黄色影院 | 狠狠操综合网 |