BohYoh.comトップページへ

新・明解Javaで学ぶアルゴリズムとデータ構造

戻る  

演習6-17の解答

 List 6-15の配列x を、身長の昇順でなく視力の降順でソートするプログラムを作成せよ。

// 演習6-17 // 身体検査データ配列のソート(視力の降順でソート) import java.util.Arrays; import java.util.Comparator; class PhyscExamSortV {    //--- 身体検査データ ---//    static class PhyscData {       String name;         // 氏名       int    height;         // 身長       double vision;         // 視力       //--- コンストラクタ ---//       public PhyscData(String name, int height, double vision) {          this.name = name;  this.height = height;  this.vision = vision;       }       //--- 文字列化 --//       public String toString() {          return name + " " + height + " " + vision;       }       //--- 視力降順用コンパレータ ---//       static final Comparator<PhyscData> VISION_RORDER =                                  new VisionROrderComparator();       private static class VisionROrderComparator                               implements Comparator<PhyscData> {          public int compare(PhyscData d1, PhyscData d2) {             return (d1.vision < d2.vision?  :                    (d1.vision > d2.vision? -0;          }       }    }    public static void main(String[] args) {       PhyscData[] x = {             new PhyscData("赤坂忠雄"1620.3),             new PhyscData("加藤富明"1730.7),             new PhyscData("斉藤正二"1752.0),             new PhyscData("武田信也"1711.5),             new PhyscData("長浜良一"1680.4),             new PhyscData("浜田哲明"1741.2),             new PhyscData("松富明雄"1690.8),          };       Arrays.sort(x,                        // 配列xを                   PhyscData.VISION_RORDER   // HEIGHT_ORDERを用いてソート                  );       System.out.println("■ 身体検査一覧表 ■");       System.out.println(" 氏名      身長 視力");       System.out.println("--------------------");       for (int i = 0; i < x.length; i++)          System.out.printf("%-8s%3d%5.1f\n",                    x[i].name, x[i].height, x[i].vision);    } }


戻る