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

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);
    }
}
全部评论
我跟你差不多  考完发现 求完平方 int 不够用啊 可能得用 Map<Long,Integer> 才行
点赞 回复 分享
发布于 2017-09-08 21:13
...n的n次方,怕不是要上天
点赞 回复 分享
发布于 2017-09-08 21:06
键值为 long double,通过30%。。。
点赞 回复 分享
发布于 2017-09-08 21:16
和大佬一样 只过了20%
点赞 回复 分享
发布于 2017-09-08 21:11
我写的跟你一样 20%
点赞 回复 分享
发布于 2017-09-08 21:11
第二题我看了就知道短时间我做不出来。。然后就去把第一题调过了。
点赞 回复 分享
发布于 2017-09-08 21:08

相关推荐

点赞 评论 收藏
分享
机械打工仔:我来告诉你原因,是因为sobb有在线简历,有些HR为了快会直接先看在线简历,初步感觉不合适就不会找你要详细的了
投了多少份简历才上岸
点赞 评论 收藏
分享
每晚夜里独自颤抖:你cet6就cet6,cet4就cet4,你写个cet证书等是什么意思。专业技能快赶上项目行数,你做的这2个项目哪里能提现你有这么多技能呢
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务