京东第二题,求错在哪里。

import java.util.HashMap;
import java.util.Map;
import java.util.Scanner;


public class Main{
    public static int deal(int n){
        int ans=0;
        int[] list=new int[n];
        for(int i=0;i<n;i++){
            list[i]=i+1;
        }
        Map<Integer,Integer> map=new HashMap<Integer,Integer>();
        for(int i=0;i<n;i++){
            for (int j=0;j<n;j++){
                int temp=(int)Math.pow(list[i],list[j]);
//                System.out.println(list[i]+"*"+list[j]+"temp="+temp);
                if(map.containsKey(temp)){
                    int count=map.get(temp);
                    map.put(temp,++count);
                }else {
                    map.put(temp,1);
                }
            }
        }
        for(Integer key:map.keySet()){
            int m=map.get(key);
//            System.out.println("m="+m);
            int sum=m+m*(m-1);
            ans+=sum;
        }

        return ans;
    }

    public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        int n=sc.nextInt();
        int rr=deal(n);
        int ans=rr%1000000007;
        System.out.println(ans);
    }
}
全部评论
...n的n次方,怕不是要上天
点赞 回复 分享
发布于 2017-09-08 21:06
我跟你差不多  考完发现 求完平方 int 不够用啊 可能得用 Map<Long,Integer> 才行
点赞 回复 分享
发布于 2017-09-08 21:13
第二题我看了就知道短时间我做不出来。。然后就去把第一题调过了。
点赞 回复 分享
发布于 2017-09-08 21:08
我写的跟你一样 20%
点赞 回复 分享
发布于 2017-09-08 21:11
和大佬一样 只过了20%
点赞 回复 分享
发布于 2017-09-08 21:11
键值为 long double,通过30%。。。
点赞 回复 分享
发布于 2017-09-08 21:16

相关推荐

评论
点赞
收藏
分享
牛客网
牛客企业服务