已知有十六支男子足球队,参加2008 北京奥运会。写一个程序,把这16 支球队随机分为4 个组。

47 篇文章 9 订阅

已知有十六支男子足球队参加2008 北京奥运会。写一个程序,把这16 支球队随机分为4 个组。
要求:采用List集合和随机数放入map集合中,遍历map集合打印结果:

例如:第一组:中国 美国 澳大利亚 巴西

           。。。。。。。

2008 北京奥运会男足参赛国家:
科特迪瓦","阿根廷","澳大利亚","塞尔维亚","荷兰","尼日利亚","日本",
"美国","中国","新西兰","巴西","比利时","韩国","喀麦隆","洪都拉斯","意大利

首先创建一个集合,用Collections.addAll添加所有的国家到集合中:

 ArrayList<String>list=new ArrayList<String>();
    Collections.addAll(list, "科迪瓦特","阿根廷","澳大利亚","塞尔维亚","荷兰",
            "尼日利亚","日本","美国","中国","新西兰","巴西","比利时","韩国","喀麦隆","洪都拉斯","意大利");

因为每组四个队,需要判断每个队是否满足四个,满足不添加,不满足,添加,此外如果已经满足了四个则需要i--,让循环再次进行,直到所有队伍组成完整,并且通过put方法添加到map集合中:

 int g1=0,g2=0,g3=0,g4=0;
    Random r=new Random();
    Map<String,Integer>group=new HashMap<String, Integer>();
    int j;
    for(int i=0;i<list.size();i++)
    {
        j=r.nextInt(4)+1;
        if(j==1&&g1<4)
        {
          group.put(list.get(i),j);
          g1++;
        }
        else if(j==2&&g2<4)
        {
            group.put(list.get(i),j);
            g2++;
        }
        else if(j==3&&g3<4)
        {
            group.put(list.get(i),j);
            g3++;
        }
        else if(j==4&&g4<4)
        {
            group.put(list.get(i),j);
            g4++;
        }
        else {
        i--;
        }
    } 

 第一种方法遍历输出map集合:

键值对

for(int i=1;i<=4;i++)
    {
        System.out.print("第"+i+"组:");
        for(Entry<String, Integer>entry:group.entrySet()) {
            if(entry.getValue().equals(i))
            {
                System.out.print(entry.getKey()+" ");
            }
        }
        System.out.println(" ");
    }

第二种方法遍历输出map集合:

迭代器

for(int i=1;i<=4;i++)
    {
        System.out.print("第"+i+"组:");
        Set kSet=group.keySet();
        Iterator it=kSet.iterator();
        while(it.hasNext())
        {
            Object key=(Object)it.next();
            Object value=group.get(key);
            if(value.equals(i))
            {
                System.out.print(key+" ");
            }
        }
        System.out.println(" ");
    } 

完整代码:

package act;
import java.util.*;
import java.util.Map.Entry;
public class Test3 {
    public static void main(String[] args) {
        // TODO Auto-generated method stub
    ArrayList<String>list=new ArrayList<String>();
    Collections.addAll(list, "科迪瓦特","阿根廷","澳大利亚","塞尔维亚","荷兰",
            "尼日利亚","日本","美国","中国","新西兰","巴西","比利时","韩国","喀麦隆","洪都拉斯","意大利");
    int g1=0,g2=0,g3=0,g4=0;
    Random r=new Random();
    Map<String,Integer>group=new HashMap<String, Integer>();
    int j;
    for(int i=0;i<list.size();i++)
    {
        j=r.nextInt(4)+1;
        if(j==1&&g1<4)
        {
          group.put(list.get(i),j);
          g1++;
        }
        else if(j==2&&g2<4)
        {
            group.put(list.get(i),j);
            g2++;
        }
        else if(j==3&&g3<4)
        {
            group.put(list.get(i),j);
            g3++;
        }
        else if(j==4&&g4<4)
        {
            group.put(list.get(i),j);
            g4++;
        }
        else {
        i--;
        }
    }
    /*for(int i=1;i<=4;i++)
    {
        System.out.print("第"+i+"组:");
        for(Entry<String, Integer>entry:group.entrySet()) {
            if(entry.getValue().equals(i))
            {
                System.out.print(entry.getKey()+" ");
            }
        }
        System.out.println(" ");
    }
    */
    for(int i=1;i<=4;i++)
    {
        System.out.print("第"+i+"组:");
        Set kSet=group.keySet();
        Iterator it=kSet.iterator();
        while(it.hasNext())
        {
            Object key=(Object)it.next();
            Object value=group.get(key);
            if(value.equals(i))
            {
                System.out.print(key+" ");
            }
        }
        System.out.println(" ");
    }
    }

代码运行结果:

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

香蕉不拉了

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值