結果

問題 No.2740 Old Maid
ユーザー koufu193
提出日時 2024-04-21 11:33:25
言語 Java
(openjdk 23)
結果
TLE  
実行時間 -
コード長 1,775 bytes
コンパイル時間 2,143 ms
コンパイル使用メモリ 86,352 KB
実行使用メモリ 156,780 KB
最終ジャッジ日時 2024-10-13 10:08:12
合計ジャッジ時間 9,346 ms
ジャッジサーバーID
(参考情報)
judge4 / judge3
このコードへのチャレンジ
(要ログイン)
ファイルパターン 結果
sample -- * 3
other TLE * 1 -- * 61
権限があれば一括ダウンロードができます

ソースコード

diff #

import java.util.*;

public class Main {
    public static void main(String[] args) {
        int offset=0;

        Scanner sc=new Scanner(System.in);
        int len=sc.nextInt();
        int[] arr=new int[len];
        int[] result=new int[len];
        for(int i=0;i<len;i++){
            arr[i]=sc.nextInt();
        }
        int a=0;
        while(a<len){
            Value min=findMin(arr);
            result[offset++]=min.a;
            result[offset++]=min.b;
            arr[min.offsetA]=0;
            arr[min.offsetB]=0;
            a+=2;
        }
        StringBuilder builder=new StringBuilder(len*4);
        for(Integer c:result){
            builder.append(c).append(" ");
        }
        System.out.println(builder.toString().replaceFirst(" $",""));
    }
    private static Value findMin(int[] arr){
        int minA=Integer.MAX_VALUE;
        int minB=Integer.MAX_VALUE;

        int offsetA=-1;
        int offsetB=-1;


        int firstIndex=Math.max(skipZeros(arr),1);

        int prevOffset=firstIndex-1;
        int prev=arr[prevOffset];

        for(int i=firstIndex;i<arr.length;i++){
            int v=arr[i];
            if(v==0) continue;

            if(minA<prev){
                prevOffset=i;
                prev=v;
                continue;
            }
            offsetA=prevOffset;
            offsetB=i;

            minA=prev;
            minB=v;

            prevOffset=i;
            prev=v;
        }
        return new Value(minA,minB,offsetA,offsetB);
    }
    private static int skipZeros(int[] arr){
        for(int i=0;i<arr.length;i++){
            if(arr[i]!=0){
                return i;
            }
        }
        return -1;
    }
    private record Value(Integer a, Integer b, int offsetA,int offsetB){}
}
0