結果

問題 No.16 累乗の加算
ユーザー SagTokiSagToki
提出日時 2018-05-29 13:26:55
言語 Java
(openjdk 23)
結果
TLE  
実行時間 -
コード長 2,452 bytes
コンパイル時間 3,365 ms
コンパイル使用メモリ 78,712 KB
実行使用メモリ 54,392 KB
最終ジャッジ日時 2024-06-30 08:01:18
合計ジャッジ時間 10,311 ms
ジャッジサーバーID
(参考情報)
judge5 / judge4
このコードへのチャレンジ
(要ログイン)

テストケース

テストケース表示
入力 結果 実行時間
実行使用メモリ
testcase_00 AC 127 ms
54,232 KB
testcase_01 AC 133 ms
54,392 KB
testcase_02 TLE -
testcase_03 -- -
testcase_04 -- -
testcase_05 -- -
testcase_06 -- -
testcase_07 -- -
testcase_08 -- -
testcase_09 -- -
testcase_10 -- -
testcase_11 -- -
testcase_12 -- -
testcase_13 -- -
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.math.BigDecimal;
import java.util.Scanner;
import java.util.InputMismatchException;

public class AdditionOfPowers {
    public static void main(String[] args){
        int[] N =Input();
        Processing(N);
        BigDecimal Count = BigDecimal.ZERO;
        for(int i = 0 ; i < N.length - 2 ; i++){
            Count = Count.add(Processing(N)[i]);
        }
        System.out.println(Count);
    }

    //数値を入力して範囲が正しいかを判定するメソッド
    public static int[] Input(){
        Scanner scanner = new Scanner(System.in);
        int X = scanner.nextInt();
        int N = scanner.nextInt();
        int[] Store = new int[N + 2];
        Store[0] = X;
        Store[1] = N;
        try{
        //Xの条件判定
        if(X < 1 || X > 100){
            System.out.println("Xは1以上100以下の数字で入力してください");
            System.exit(0);
        }
        //Nの条件判定
        if(N < 1 || N > 100){
            System.out.println("Nは1以上100以下の数字で入力してください");
            System.exit(0);
        }
        //各項の入力と条件判定
        for(int i = 2 ; i < N + 2 ; i++){
            int Z = scanner.nextInt();
            Store[i] = Z;
            if(Z < 0 || Z > Math.pow(10,8)){
                System.out.println("各項は0以上10000000以下で入力してください");
                System.exit(0);
            }
        }
        }catch(InputMismatchException e){
            System.out.println("数字を入力してください");
            System.exit(0);
        }catch(Exception E){
            System.out.println("想定外のエラーです");
        }
        return Store;
    }
    
    //計算を実行するメソッド
    public static BigDecimal[] Processing(int[] Store){
        int X = Store[0];
        int N = Store[1];
        BigDecimal Sum = BigDecimal.ZERO ;
        BigDecimal[] ans = new BigDecimal[N];
        int[] NewStore = new int[N];
        BigDecimal big1 = BigDecimal.valueOf(1000003);
        
        //新しい配列に旧配列を代入するループ
        for(int i = 0 ; i < N ; i++){
            NewStore[i] = Store[i + 2];
        }
        //ans配列に各項の累乗値を代入させるループ
        for(int j = 0 ; j < N ; j++){
            ans[j] = BigDecimal.valueOf(X).pow(NewStore[j]).remainder(big1);
        } 
        
        return ans;
    }
}
0