java做一個值日生表。要用到連結串列,random,list。一共十三個人,四個人一組,最後剩下一個自己一個集合。不能重複
package com.wanju.project001.zonghe.test;
import java.util.LinkedList;
import java.util.List;
import java.util.Random;
public class TestWork {
public static final int ALL_NUM = 13;
List<Student> ls = new LinkedList<Student>();
List<Student> lsForCopy = new LinkedList<Student>();
List<LinkedList<Student>> lss = new LinkedList<LinkedList<Student>>();
public void init() {
for (int i = 0; i < ALL_NUM; i++) {
Student s = new Student();
s.setNum(i);
s.setName("s" + i);
ls.add(s);
}
}
public static void main(String[] args) {
TestWork t = new TestWork();
t.init();
t.group();
t.show();
}
public void group() {
for (int i = 0; i < 4; i++) {
lss.add(new LinkedList<Student>());
}
boolean flg = true;
Random r = new Random();
StudentHelper helper = new StudentHelper(ls);
helper.setLsForCopy(lsForCopy);
for (int k = 0; k < 4; k++) {
for (int i = 0; i < 4; i++) {
while (flg) {
int v = r.nextInt(ls.size());
if (!helper.checkStudentByNum(v)) {
Student ss = helper.getStudentByNum(v);
lss.get(k).add(ss);
lsForCopy.add(ss);
helper.addLsForCopyStudent(ss);
if (lss.get(k).size() >= 4) {
flg = false;
}
if (k == 3) {
flg = false;
}
break;
}
}
}
flg = true;
}
}
public void show() {
for (int i = 0; i < lss.size(); i++) {
System.out.println(lss.get(i));
}
}
}
class Student {
private int num;
private String name;
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Student [num=" + num + ", name=" + name + "]";
}
}
class StudentHelper {
List<Student> ls = new LinkedList<Student>();
List<Student> lsForCopy = new LinkedList<Student>();
public List<Student> getLsForCopy() {
return lsForCopy;
}
public void setLsForCopy(List<Student> lsForCopy) {
this.lsForCopy = lsForCopy;
}
public void addLsForCopyStudent(Student s) {
lsForCopy.add(s);
}
public StudentHelper() {
}
public StudentHelper(List<Student> ls) {
this.ls = ls;
}
public Student getStudentByNum(int v) {
for (int i = 0; i < ls.size(); i++) {
if (ls.get(i).getNum() == v) {
return ls.get(i);
}
}
return null;
}
public boolean checkStudentByNum(int v) {
return getStudentByNumFromLsForCoby(v) == null ? false : true;
}
public Student getStudentByNumFromLsForCoby(int v) {
for (int i = 0; i < lsForCopy.size(); i++) {
if (lsForCopy.get(i).getNum() == v) {
return lsForCopy.get(i);
}
}
return null;
}
}
import java.util.LinkedList;
import java.util.List;
import java.util.Random;
public class TestWork {
public static final int ALL_NUM = 13;
List<Student> ls = new LinkedList<Student>();
List<Student> lsForCopy = new LinkedList<Student>();
List<LinkedList<Student>> lss = new LinkedList<LinkedList<Student>>();
public void init() {
for (int i = 0; i < ALL_NUM; i++) {
Student s = new Student();
s.setNum(i);
s.setName("s" + i);
ls.add(s);
}
}
public static void main(String[] args) {
TestWork t = new TestWork();
t.init();
t.group();
t.show();
}
public void group() {
for (int i = 0; i < 4; i++) {
lss.add(new LinkedList<Student>());
}
boolean flg = true;
Random r = new Random();
StudentHelper helper = new StudentHelper(ls);
helper.setLsForCopy(lsForCopy);
for (int k = 0; k < 4; k++) {
for (int i = 0; i < 4; i++) {
while (flg) {
int v = r.nextInt(ls.size());
if (!helper.checkStudentByNum(v)) {
Student ss = helper.getStudentByNum(v);
lss.get(k).add(ss);
lsForCopy.add(ss);
helper.addLsForCopyStudent(ss);
if (lss.get(k).size() >= 4) {
flg = false;
}
if (k == 3) {
flg = false;
}
break;
}
}
}
flg = true;
}
}
public void show() {
for (int i = 0; i < lss.size(); i++) {
System.out.println(lss.get(i));
}
}
}
class Student {
private int num;
private String name;
public int getNum() {
return num;
}
public void setNum(int num) {
this.num = num;
}
public String getName() {
return name;
}
public void setName(String name) {
this.name = name;
}
@Override
public String toString() {
return "Student [num=" + num + ", name=" + name + "]";
}
}
class StudentHelper {
List<Student> ls = new LinkedList<Student>();
List<Student> lsForCopy = new LinkedList<Student>();
public List<Student> getLsForCopy() {
return lsForCopy;
}
public void setLsForCopy(List<Student> lsForCopy) {
this.lsForCopy = lsForCopy;
}
public void addLsForCopyStudent(Student s) {
lsForCopy.add(s);
}
public StudentHelper() {
}
public StudentHelper(List<Student> ls) {
this.ls = ls;
}
public Student getStudentByNum(int v) {
for (int i = 0; i < ls.size(); i++) {
if (ls.get(i).getNum() == v) {
return ls.get(i);
}
}
return null;
}
public boolean checkStudentByNum(int v) {
return getStudentByNumFromLsForCoby(v) == null ? false : true;
}
public Student getStudentByNumFromLsForCoby(int v) {
for (int i = 0; i < lsForCopy.size(); i++) {
if (lsForCopy.get(i).getNum() == v) {
return lsForCopy.get(i);
}
}
return null;
}
}
相關文章
- 一個統一的連結串列結構 (轉)
- java lambda list集合中物件某屬性重複,只取第一個物件Java物件
- 敏捷個人-做好一個開發者敏捷
- 集合第一個Array List理解
- 從連結串列出發封裝一個自己的工具封裝
- [leetcode 25]. K 個一組翻轉連結串列LeetCode
- JAVA面試題筆試題-查詢一個字串不重複最長的串(個人方法)Java面試題筆試字串
- 【Java面試題】54 去掉一個Vector集合中重複的元素Java面試題
- LeetCode 25. k個一組翻轉連結串列LeetCode
- 一個兩年java程式猿的2017個人總結Java
- 連結串列面試題(一)---刪除一個無頭單連結串列的非尾結點面試題
- 定義一個函式,輸入一個連結串列的頭節點,反轉該連結串列並輸出反轉後連結串列的頭節點函式
- 連結串列面試題(九)---判斷一個連結串列是否帶環面試題
- Java的整個字串的結束索引在最後一個字元之外Java字串索引字元
- 一個node連結串列翻轉的面試題面試題
- 分享自己做的一個JAVA RPC 框架 longioJavaRPC框架
- java8的stream將一個List轉為按照某個欄位分組的map,再按照另一個欄位取max最終得到一個mapJava
- 引用一個連結,後續學習。
- 做一個自己的工作列 (轉)
- 給自己組一個本地儲存
- 「複製帶隨機指標的連結串列」的一個很巧妙解法隨機指標
- [每日一題] 第十三題:連結串列中倒數第k個節點每日一題
- 連結串列的作用和好處?如何用JS來寫一個連結串列JS
- 做一個有想法的程式設計師,做一個屬於自己的神器程式設計師
- 自己寫一個mvc框架吧(四)MVC框架
- jquery如何獲取第一個或最後一個子元素?jQuery
- js 字串中取得第一個字元和最後一個字元JS字串字元
- TODO list小工具,給自己一個交代
- VI 跳到最後一行和跳到最後一行的最後一個字元字元
- 搭建個人圖書館!一個簡單的線上個人書庫
- 劍指offer——兩個連結串列的第一個公共結點C++C++
- CloudNotes:一個雲端個人筆記系統Cloud筆記
- 一個奇怪的Java集合問題Java
- 一個rm -rf *命令執行後, 整個人都不好了
- VI操作--跳到最後一行和跳到最後一行的最後一個字元字元
- script取一個月的最後一天
- 自己實現一個java的arraylistJava
- java 獲取上月、一個月最後一天、週一、週日、本月日期Java