UVA10474查找优化

ArrayList.indexOf效率很低,
HashMap.get()效率最高

import java.util.*;

/**
 * Created by 95112 on 10/19/2017.
 */
public class Main {
    public static void main(String[] args)
    {
        Scanner scanner = new Scanner(System.in);
        List<List<String>> answers = new ArrayList<>();
        int N, Q;

        ArrayList<Integer> map;
        int count = 0;
        do {
            N  = scanner.nextInt();
            Q = scanner.nextInt();
            if (N == 0 && Q == 0)
                break;
            answers.add(new ArrayList());
            map = new ArrayList<>();
            int input ;
            for (int i=0 ;i < N; i++)
            {
                input = scanner.nextInt();
                map.add(input);
            }
            Collections.sort(map);
            HashMap<Integer,Integer> test = new HashMap<>();
            int tmp ;
            for (int i = 0 ; i < map.size(); i++)
            {
                tmp = map.get(i);
                if (!test.containsKey(tmp))
                    test.put(tmp,i+1);
            }
            for (int i = 0 ; i < Q; i++)
            {
                input = scanner.nextInt();
                if (test.containsKey(input))
                {

                    answers.get(count).add(input + " found at "+ (test.get(input)));
                }
                else
                {
                    answers.get(count).add(input + " not found");
                }
            }
            count++;

        }while (true);
        for (int i = 0; i < answers.size();i++)
        {
            System.out.println("CASE# "+ (i+1)+":");
            for (String answer : answers.get(i))
                System.out.println(answer);
        }
    }
}
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值