首页 诗词 字典 板报 句子 名言 友答 励志 学校 网站地图
当前位置: 首页 > 教程频道 > 开发语言 > 编程 >

Java练习 比赛分组,使每组人员相差最少

2012-10-26 
Java习题比赛分组,使每组人员相差最少/* * 分组问题,有一个8道的跑道 * 如果有9人参加比赛,则将比赛人员分

Java习题 比赛分组,使每组人员相差最少
/*
* 分组问题,有一个8道的跑道
* 如果有9人参加比赛,则将比赛人员分成两组:5、4
* 如果有8人参加比赛,则将比赛人员分成一组:8
* 如果有25人参加比赛,则将比赛人员分成四组:
* 7
* 6
* 6
* 6
* 尽量使每组人员相差最少,每行输出一组人数,按从大到小输出
*/

import java.util.ArrayList;
import java.util.List;
import java.util.Scanner;

public class Questions_4 {

public static void main(String[] args) {
Scanner sc = new Scanner(System.in);
System.out.print("输入参赛人数:");
int participants = sc.nextInt();//参赛人数
int groups = 0;//组数
List<Integer> list=new ArrayList<Integer>();//每组人数
int temp=0;

System.out.println("参赛人数是:"+participants+"人");

//求分组数
if (participants % 8 == 0)
groups = participants / 8;
else
groups = participants / 8 + 1;

while(groups>=1){
temp=participants/groups;//求本组人数
list.add(temp);//添加到集合中
participants-=temp;//减掉已分到组的人数
groups--;//组数-1
}

for(int i=0;i<list.size();i++)
System.out.println("第"+(i+1)+"组:"+list.get(i)+"人");
}
}

热点排行