请教!!!POJ: 1007一直wrong answer,换一种写法就AC,其实是一样的。。

WA代码:

package Main;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.HashMap;
import java.util.List;
import java.util.Map;
import java.util.Map.Entry;
import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        Map<String, Integer> map = new HashMap<String, Integer>();

        if (scanner.hasNext()) {
            int n = scanner.nextInt();
            int m = scanner.nextInt();

            for (int i = 0; i < m; i++) {
                String line = scanner.next();
                int count = 0;

                for (int j = 0; j < n - 1; j++) {
                    for (int j2 = j + 1; j2 < n; j2++) {
                        if (line.charAt(j) > line.charAt(j2)) {
                            count++;
                        }
                    }
                }

                map.put(line, count);
            }

        }

        scanner.close();

        List<Map.Entry<String, Integer>> list = new ArrayList<Map.Entry<String, Integer>>(map.entrySet());
        Collections.sort(list, new comparator());

        for (Map.Entry<String, Integer> mapping : list) {
            System.out.println(mapping.getKey());
        }

    }
}

class comparator implements Comparator<Map.Entry<String, Integer>>{
    public int compare(Entry<String, Integer> o1, Entry<String, Integer> o2) {
        return o1.getValue().compareTo(o2.getValue());
    }
}

AC代码:

package Main;

import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);

        List<DNA> list = new ArrayList<DNA>();

        if (scanner.hasNext()) {
            int n = scanner.nextInt();
            int m = scanner.nextInt();

            for (int i = 0; i < m; i++) {
                String line = scanner.next();
                int count = 0;

                for (int j = 0; j < n - 1; j++) {
                    for (int j2 = j + 1; j2 < n; j2++) {
                        if (line.charAt(j) > line.charAt(j2)) {
                            count++;
                        }
                    }
                }

                list.add(new DNA(line, count));
            }

        }

        scanner.close();

        Collections.sort(list, new comparator());

        for (DNA dna : list) {
            System.out.println(dna.getText());
        }

    }
}

class comparator implements Comparator<DNA> {
    public int compare(DNA o1, DNA o2) {
        return o1.getNum() > o2.getNum() ? 1 : (o1.getNum() == o2.getNum() ? 0 : -1);
    }
}

class DNA {

    public String text;
    public int num;

    public DNA(String text, int num) {
        this.text = text;
        this.num = num;
    }

    public String getText() {
        return text;
    }

    public void setText(String text) {
        this.text = text;
    }

    public int getNum() {
        return num;
    }

    public void setNum(int num) {
        this.num = num;
    }
}
  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值