Java代码实现了一个整数分组功能

alt

-CoderOilStation(程序员编程助手科技股份责任有限公司)

Java代码实现了一个整数分组功能

package com.javaTest;

import java.util.ArrayList;
import java.util.HashSet;
import java.util.List;
import java.util.Objects;
import java.util.Random;
import java.util.UUID;

public class JavaTest {
	public static void main(String[] args) {
		System.out.println("Hello World!");
		int[] nums=new int[] {1,2,3,4,5};
		List<ArrayList<CustIntGroup>> diffGroupIntegerList = getDiffGroupIntegerList(nums);
		System.out.println(diffGroupIntegerList);
		ArrayList<Integer> arrayList = new ArrayList<Integer>();
		arrayList.add(1);
		arrayList.add(2);
		arrayList.add(2);
		Boolean checkIntArrEleIsUnique = checkIntArrEleIsUnique(arrayList);
		System.out.println(checkIntArrEleIsUnique);
	}
	public static List<ArrayList<CustIntGroup>> getDiffGroupIntegerList(int[] nums){
		if(nums==null) {
			return null;
		}
		if(nums.length==0) {
			return null;
		}
		if(nums.length<1 || nums.length>6) {
			return null;
		}
		HashSet<Integer> hashSet = new HashSet<Integer>();
		for (int i = 0; i < nums.length; i++) {
			int j = nums[i];
			if(j<0 || j>10) {
				return null;
			}
			hashSet.add(j);
		}
		if(hashSet.size()<nums.length) {
			return null;
		}
		List<ArrayList<CustIntGroup>> arrayList = new ArrayList<ArrayList<CustIntGroup>>();
		Random random = new Random();
		HashSet<CustIntGroup> hashSet2 = new HashSet<CustIntGroup>();
		int count=0;
		while(true) {
			ArrayList<Integer> arrayList3 = new ArrayList<Integer>();
			for (int j = 0; j < nums.length; j++) {
				CustIntGroup custIntGroup = new CustIntGroup();
				custIntGroup.setId(UUID.randomUUID().toString());
				int nextInt = random.nextInt(nums.length);
				int i = nums[nextInt];
				arrayList3.add(i);
				if(arrayList3.size()<nums.length) {
					continue;
				}
				if(checkIntArrEleIsUnique(arrayList3)) {
					custIntGroup.setIntArr(arrayList3);
				}
				hashSet2.add(custIntGroup);
			}
			ArrayList<CustIntGroup> arrayList2 = new ArrayList<CustIntGroup>();
			hashSet2.forEach(e->{
				arrayList2.add(e);
			});
			arrayList.add(arrayList2);
			count++;
			if(count>1000000) {
				break;
			}
		}
		return arrayList;
	}
	public static Boolean checkIntArrEleIsUnique(List<Integer> intList) {
		if(intList==null) {
			return null;
		}
		if(intList.isEmpty()) {
			return null;
		}
		HashSet<Integer> hashSet = new HashSet<Integer>();
		intList.forEach(e->{
			hashSet.add(e);
		});
		if(hashSet.size()<intList.size()) {
			return false;
		}
		return true;
	}
}
class CustIntGroup{
	private String id;
	private List<Integer> intArr;
	public String getId() {
		return id;
	}
	public void setId(String id) {
		this.id = id;
	}
	public List<Integer> getIntArr() {
		return intArr;
	}
	public void setIntArr(List<Integer> intArr) {
		this.intArr = intArr;
	}
	@Override
	public int hashCode() {
		return Objects.hash(intArr);
	}
	@Override
	public boolean equals(Object obj) {
		if (this == obj)
			return true;
		if (obj == null)
			return false;
		if (getClass() != obj.getClass())
			return false;
		CustIntGroup other = (CustIntGroup) obj;
		return Objects.equals(intArr, other.intArr);
	}
	
}
#计算机有哪些岗位值得去?##社会教会你的第一课##牛客创作赏金赛##神州信息工作体验#
Java技术 文章被收录于专栏

JavaEE技术 编程开发经验 企业通用技术

全部评论
6啊
点赞 回复 分享
发布于 昨天 15:23 上海
我靠
点赞 回复 分享
发布于 昨天 15:22 浙江
厉害厉害
点赞 回复 分享
发布于 昨天 15:22 广东

相关推荐

07-07 11:00
已编辑
西南大学 后端
冰冰可爱:其实就是不烂大街的同时自己对项目有点深入的了解,为什么选这个不选那个,选这个好在哪,还有没有更好,有思考深度的项目确实能帮自己在面试的时候更加加分,就有脱颖而出的机会,但对学生来说面试的要求越来越高了,也不是好事
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务