結果
| 問題 | No.297 カードの数式 | 
| コンテスト | |
| ユーザー |  kenji_shioya | 
| 提出日時 | 2016-06-12 20:49:11 | 
| 言語 | Java (openjdk 23) | 
| 結果 | 
                                AC
                                 
                             | 
| 実行時間 | 197 ms / 1,000 ms | 
| コード長 | 1,910 bytes | 
| コンパイル時間 | 5,504 ms | 
| コンパイル使用メモリ | 85,656 KB | 
| 実行使用メモリ | 41,772 KB | 
| 最終ジャッジ日時 | 2024-12-26 02:31:50 | 
| 合計ジャッジ時間 | 11,534 ms | 
| ジャッジサーバーID (参考情報) | judge2 / judge1 | 
(要ログイン)
| ファイルパターン | 結果 | 
|---|---|
| sample | AC * 3 | 
| other | AC * 23 | 
ソースコード
import java.util.*;
public class Exercise79{
  public static void main (String[] args){
    Scanner sc = new Scanner(System.in);
    int n = sc.nextInt();
    ArrayList<String> nums = new ArrayList<String>();
    ArrayList<String> operators = new ArrayList<String>();
    for(int i = 0; i < n; i++){
      try{
        int x = sc.nextInt();
        nums.add(String.valueOf(x));
      }catch (InputMismatchException e){
        operators.add(sc.next());
      }
    }
    Collections.sort(nums);
    Collections.sort(operators);
    // max
    long sum = 0;
    long minus = 0;
    String maxNum = "";
    for (int i = nums.size() - 1; i >= operators.size(); i--){
      maxNum += nums.get(i);
    }
    sum += Long.parseLong(maxNum);
    for(int i = 0; i < operators.size(); i++){
      if(operators.get(i).equals("+")){
        sum += Long.parseLong(nums.get(operators.size() - 1 - i));
      }else{
        sum -= Long.parseLong(nums.get(operators.size() - 1 - i));
      }
    }
    //min
    maxNum = "";
    if(operators.indexOf("-") != -1){
      for (int i = nums.size() - 1; i >= operators.size(); i--){
        maxNum += nums.get(i);
      }
      minus += Long.parseLong(nums.get(0));
      for(int i = 0; i < operators.size() - 1; i++){
        if(operators.get(i).equals("+")){
          minus += Long.parseLong(nums.get(i + 1));
        }else{
          minus -= Long.parseLong(nums.get(i + 1));
        }
      }
      minus -= Long.parseLong(maxNum);
    }else{
      String[] numArray = new String[operators.size() + 1];
      for(int i = 0; i < numArray.length; i++){
        numArray[i] = "";
      }
      for(int i = 0; i < nums.size(); i++){
        numArray[i % numArray.length] += nums.get(i);
      }
      for(int i = 0; i < numArray.length; i++){
        minus += Long.parseLong(numArray[i]);
      }
    }
    System.out.print(sum + " ");
    System.out.println(minus);
  }
}
            
            
            
        