可定制排序的矩形 (20 分)

可定制排序的矩形 (20 分)
从键盘录入表示矩形个数的数字n,然后录入n个矩形的长和宽,然后对这n个矩形按照面积从大到小排序,并输出排序后的每个矩形的面积。要求:请设计Rectangle类,包含相应的构造函数和成员函数,实现Comparable接口

输入描述:
矩形个数,每个矩形的长和宽

输出描述:
由大到小排序的每个矩形的面积

裁判测试程序样例:
import java.util.Comparator;
import java.util.Arrays;
import java.util.Scanner;

/你的代码被嵌在这里/

public class Main {
public static void main(String[] args) {

    Scanner scan = new Scanner(System.in);
    //输入矩形个数
    int num_rectangle = scan.nextInt();
    Rectangle[]  recs = new Rectangle[num_rectangle];
    //输入每个矩形的长和宽
    for(int i=0;i<num_rectangle;i++){
        int length = scan.nextInt();
        int width = scan.nextInt();
        Rectangle rec = new Rectangle(length,width);
        recs[i] = rec;
    }
    //按照面积由大到小排序
    Arrays.sort(recs);
    //打印前n-1个矩形的面积
    for(int i=0;i<recs.length-1;i++){
        System.out.print(recs[i].getArea()+",");
    }
    //打印最后一个矩形的面积
    System.out.print(recs[recs.length-1].getArea());
    scan.close();
}

}
输入样例:
在这里给出一组输入。例如:

3 1 2 3 4 2 3
输出样例:
在这里给出相应的输出。例如:

12,6,2

class Rectangle implements Comparable{
	int length;
	int width;
	int area;
	public Rectangle(int length, int width) {
		super();
		this.length = length;
		this.width = width;
		this.area=length*width;
	}
	@Override
	public int compareTo(Object o) {
		// TODO Auto-generated method stub
		Rectangle temp=(Rectangle) o;
		if (area<temp.area) {
			return 1;
		}
		else if (area>temp.area) {
			return -1;
		}
		else {
			return 0;
		}
	}
	public int getArea() {
		// TODO Auto-generated method stub
		return this.area;
	}
	
	
	
}
  • 1
    点赞
  • 7
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值