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

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

相关推荐

offer多多的六边形战士很无语:看了你的博客,感觉挺不错的,可以把你的访问量和粉丝数在简历里提一下,闪光点(仅个人意见)
点赞 评论 收藏
分享
沉淀一会:1.同学你面试评价不错,概率很大,请耐心等待; 2.你的排名比较靠前,不要担心,耐心等待; 3.问题不大,正在审批,不要着急签其他公司,等等我们! 4.预计9月中下旬,安心过节; 5.下周会有结果,请耐心等待下; 6.可能国庆节前后,一有结果我马上通知你; 7.预计10月中旬,再坚持一下; 8.正在走流程,就这两天了; 9.同学,结果我也不知道,你如果查到了也告诉我一声; 10.同学你出线不明朗,建议签其他公司保底! 11.同学你找了哪些公司,我也在找工作。
点赞 评论 收藏
分享
评论
点赞
收藏
分享
牛客网
牛客企业服务