Pages

Monday 19 November 2012

UVA - 10905 - Children's Game

import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.math.BigInteger;
import java.util.Arrays;

public class Main {

    public static void main(String[] args) throws IOException {
        BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
        StringBuffer sb = new StringBuffer("");
        while (true) {
            int n = Integer.parseInt(br.readLine());
            if (n == 0) {
                break;
            }
            Name[] arr = new Name[n];
            String[] str = br.readLine().split(" ");
            for (int i = 0; i < n; i++) {
                arr[i] = new Name(str[i]);
            }
            Arrays.sort(arr);
            for (int i = arr.length - 1; i > -1; i--) {
                sb.append(arr[i].getX());
            }
            sb.append("\n");
        }
        System.out.print(sb);
    }
}

class Name implements Comparable<Name> {

    String x;

    public String getX() {
        return x;
    }

    public Name(String x) {
        this.x = x;
    }

    @Override
    public int compareTo(Name o) {
        BigInteger bg1=new BigInteger(x+o.getX());
        BigInteger bg2=new BigInteger(o.getX()+x);
        return bg1.compareTo(bg2);
    }
}

No comments:

Post a Comment