JAVA 다 중 스 레 드 보너스 뺏 기 실현 예시
보너스 나 눠 주기JAVA 작업―보 너 스 를 나 누 어 주다.
보 너 스 를 빼 앗 는 것 은 스 레 드 문제 다.
사실은 비교적 간단 합 니 다.인원 수 를 설정 하고 모든 사람 이 하나의 스 레 드 를 실행 합 니 다.모든 스 레 드 는 한 번 실행 하고 보너스 가 있 으 면 뺏 습 니 다.보너스 가 없 으 면 뺏 을 수 없 기 때문에 run 함수 에서 아직 보너스 가 있 는 지 없 는 지 판단 하면 됩 니 다.
코드 구현
import java.util.Random;
import java.util.Scanner;
public class Main {
public static void main(String[] args) {
int person_num, red_pocket_num, sum_money;
Scanner scanner = new Scanner(System.in);
System.out.println(" :");
red_pocket_num = scanner.nextInt();
System.out.println(" ( ):");
sum_money = scanner.nextInt();
if(sum_money < red_pocket_num) {
System.out.println(" , 。");
return;
}
System.out.println(" :");
person_num = scanner.nextInt();
myRunnable myrunnable = new myRunnable(sum_money,red_pocket_num);
Thread []person = new Thread[person_num];
for (int i = 0; i < person_num; i++) {
person[i] = new Thread(myrunnable);
person[i].setName(" "+(i+1));
person[i].start();
}
}
}
class myRunnable implements Runnable{
private int []red_pocket;
private int num;
private int now_num;
public myRunnable(int money, int num) {
this.red_pocket = new Red_Pocket(money, num).get_red_packets();
this.num = num;
this.now_num = num;
}
@Override
public void run() {
if(this.num>0){
System.out.println(Thread.currentThread().getName()+" "+(this.num-this.now_num+1)+" : "+red_pocket[--this.now_num]+" ");
}
else{
System.out.println(Thread.currentThread().getName()+" 。");
}
}
}
class Red_Pocket{
private long seed;
private int money;
private int num;
public int[] get_red_packets() {
if(this.money < this.num) return new int[0];
Random random = new Random(this.seed);
this.seed = random.nextLong();
int[] res = new int[this.num];
double[] temp = new double[this.num];
double sum = 0;
int sum2 = 0;
for (int i = 0; i < this.num; i++) {
temp[i] = random.nextDouble();
sum += temp[i];
}
for (int i = 0; i < this.num; i++) {
res[i] = 1 + (int)(temp[i] / sum * (this.money - this.num));
sum2 += res[i];
}
res[random.nextInt(this.num)] += this.money - sum2;
return res;
}
private void init() {
this.seed = new Random(System.currentTimeMillis()).nextLong();
}
public Red_Pocket(int money,int num) {
init();
this.money = money;
this.num = num;
}
}
JAVA 다 중 스 레 드 보너스 쟁탈 의 실현 예시 에 관 한 이 글 은 여기까지 소개 되 었 습 니 다.더 많은 JAVA 다 중 스 레 드 보너스 쟁탈 내용 은 우리 의 이전 글 을 검색 하거나 아래 의 관련 글 을 계속 조회 하 시기 바 랍 니 다.앞으로 많은 응원 바 랍 니 다!
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
JAVA 객체 작성 및 제거 방법정적 공장 방법 정적 공장 방법의 장점 를 반환할 수 있습니다. 정적 공장 방법의 단점 류 공유되거나 보호된 구조기를 포함하지 않으면 이불류화할 수 없음 여러 개의 구조기 파라미터를 만났을 때 구축기를 고려해야 한다...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.