2020-11-24

7-2 图形卡片分组游戏 (60分)

掌握类的继承、多态性使用方法以及接口的应用。 具体需求参考作业指导书。 https://images.ptausercontent.com/3800d4dd-8c1f-41ba-8e97-21606d3a0e2d.pdf

输入格式:

  • 在一行上输入一串数字(1~4,整数),其中,1代表圆形卡片,2代表矩形卡片,3代表三角形卡片,4代表梯形卡片。各数字之间以一个或多个空格分隔,以“0”结束。例如:1 3 4 2 1 3 4 2 1 3 0
  • 根据第一行数字所代表的卡片图形类型,依次输入各图形的相关参数,例如:圆形卡片需要输入圆的半径,矩形卡片需要输入矩形的宽和长,三角形卡片需要输入三角形的三条边长,梯形需要输入梯形的上底、下底以及高。各数据之间用一个或多个空格分隔。

输出格式:

  • 如果图形数量非法(<=0)或图形属性值非法(数值<0以及三角形三边不能组成三角形),则输出Wrong Format
  • 如果输入合法,则正常输出,所有数值计算后均保留小数点后两位即可。输出内容如下:
  1. 排序前的各图形类型及面积,格式为[图形名称1:面积值1图形名称2:面积值2 …图形名称n:面积值n ],注意,各图形输出之间用空格分开,且输出最后存在一个用于分隔的空格,在结束符“]”之前;
  2. 输出分组后的图形类型及面积,格式为[圆形分组各图形类型及面积][矩形分组各图形类型及面积][三角形分组各图形类型及面积][梯形分组各图形类型及面积],各组内格式为图形名称:面积值。按照“Circle、Rectangle、Triangle、Trapezoid”的顺序依次输出;
  3. 各组内图形排序后的各图形类型及面积,格式同排序前各组图形的输出;
  4. 各组中面积之和的最大值输出,格式为The max area:面积值

输入样例1:

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

1 5 3 2 0

输出样例1:

在这里给出相应的输出。例如:

Wrong Format

输入样例2:

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

4 2 1 3 0
3.2 2.5 0.4 2.3 1.4 5.6 2.3 4.2 3.5

输出样例2:

在这里给出相应的输出。例如:

The original list:
[Trapezoid:1.14 Rectangle:3.22 Circle:98.52 Triangle:4.02 ]
The Separated List:
[Circle:98.52 ][Rectangle:3.22 ][Triangle:4.02 ][Trapezoid:1.14 ]
The Separated sorted List:
[Circle:98.52 ][Rectangle:3.22 ][Triangle:4.02 ][Trapezoid:1.14 ]
The max area:98.52

输入样例3:

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

2 1 2 1 1 3 3 4 4 1 1 1 2 1 0
2.3 3.5 2.5 4.5 2.1 2.6 8.5 3.2 3.1 3.6 8.5 7.5 9.1245 6.5 3.4 10.2 11.2 11.6 15.4 5.8 2.13 6.2011 2.5 6.4 18.65

输出样例3:

在这里给出相应的输出。例如:

The original list:
[Rectangle:8.05 Circle:19.63 Rectangle:9.45 Circle:21.24 Circle:226.98 Triangle:4.65 Triangle:29.80 Trapezoid:50.49 Trapezoid:175.56 Circle:105.68 Circle:14.25 Circle:120.81 Rectangle:16.00 Circle:1092.72 ]
The Separated List:
[Circle:19.63 Circle:21.24 Circle:226.98 Circle:105.68 Circle:14.25 Circle:120.81 Circle:1092.72 ][Rectangle:8.05 Rectangle:9.45 Rectangle:16.00 ][Triangle:4.65 Triangle:29.80 ][Trapezoid:50.49 Trapezoid:175.56 ]
The Separated sorted List:
[Circle:1092.72 Circle:226.98 Circle:120.81 Circle:105.68 Circle:21.24 Circle:19.63 Circle:14.25 ][Rectangle:16.00 Rectangle:9.45 Rectangle:8.05 ][Triangle:29.80 Triangle:4.65 ][Trapezoid:175.56 Trapezoid:50.49 ]
The max area:1601.31

输入样例4:

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

1 1 3 0
6.5 12.54 3.6 5.3 6.4

输出样例4:

在这里给出相应的输出。例如:

The original list:
[Circle:132.73 Circle:494.02 Triangle:9.54 ]
The Separated List:
[Circle:132.73 Circle:494.02 ][][Triangle:9.54 ][]
The Separated sorted List:
[Circle:494.02 Circle:132.73 ][][Triangle:9.54 ][]
The max area:626.75

代码如下:

import java.util.ArrayList;
import java.util.Collections;
import java.util.Scanner;
class Xingzhuang 
{
		private String kapianName;
		Xingzhuang()
		{
			
		}
		Xingzhuang(String kapianName)
		{
			this.kapianName=kapianName;
		}
		public String getKapianName() 
		{
			return kapianName;
		}
		public void setKapianName(String KapianName) 
		{
			this.kapianName=KapianName;
		}
		public double getArea() 
		{
			return 0.0;
		}
		public boolean check() 
		{
			return true;
		}
}
class Circle extends  Xingzhuang
{
	private double r;
	public Circle(double r) 
	{
	       this.r = r;
	}
	public double getR() 
	{
	       return r;
	}
	public void setR(double r )
	{
	       this.r = r;
	}
	public double getArea()//圆面积
	{
		return Math.PI*r*r;
	}
	public  boolean check(double r)
	{
		if(r<=0)
		{
			return false;
		}
		else
			return true;
	}
}
class Rectangle extends  Xingzhuang
{
	private double w;
	private double l;
	public Rectangle()
	{
	}
	public Rectangle(double l,double w)
    {
        this.w=w;
        this.l=l;
    }
    public double getWidth() 
    {
        return w;
    }
    public void setWidth(double w)
    {
        this.w = w;
    }
    public double getLength() 
    {
        return l;
    }
    public void setLength(double l)
    {
        this.l = l;
    }
    public double getArea()
    {
        return l*w;
    }
    public  boolean check(double w,double l)
	{
		if(w<0||l<0)
		{
			return false;
		}
		else
			return true;
	}
}
class Triangle extends  Xingzhuang
{
	private double x;
	private double y;
	private double z;
	public Triangle()
	{
	}
	public Triangle(double x,double y,double z)
    {
        this.x=x;
        this.y=y;
        this.z=z;
    }
    public double getArea()//三角形面积
	{
    	double p=(x+y+z)/2;
		return Math.sqrt(p*(p-x)*(p-y)*(p-z));
	}
    public  Boolean check(double x,double y,double z)
	{
		if(x+y<=z||x+z<=y&&y+z<=x||x<0&&y<0&&z<0)
		{
			return false;
		}
		else
			return true;
	}
}
class Trapezoid extends  Xingzhuang
{
	private double x;
	private double y;
	private double z;
	public Trapezoid()
	{
	}
	public Trapezoid(double x,double y,double z)
    {
        this.x=x;
        this.y=y;
        this.z=z;
    }
    public double getArea()
	{
		return (x+y)*z/2;
	}
    public  Boolean check(double x,double y,double z)
	{
		if(x<0||y<0&&z<0)
		{
			return false;
		}
		else
			return true;
	}
}
public class Main
{
public static boolean checkABC(double a,double b,double c)
	{
		if(a<0||b<0||c<0)
		{
			return false;
		}
		else
			return true;
	}


    
public static Scanner input = new Scanner(System.in);
	public static void main(String[] args) 
	{// TODO Auto-generated method stub
		//Scanner in = new Scanner(System.in);
		ArrayList<Integer> list = new ArrayList<Integer>();
		int num = input.nextInt(); 
		
		while(num != 0)
		{    
			if(num < 0 || num > 4)
			{     
				System.out.println("Wrong Format");   
				System.exit(0);    
			}         
			list.add(num);          
			num = input.nextInt();  
		}   
		Kapianlist kapianlist = new Kapianlist(list);
		if(!kapianlist.check())
		{
			System.out.println("Wrong Format");
			System.exit(0);
		}
		kapianlist.showResult();
		input.close();
	}	
}
class Kapian
{
	Xingzhuang xingzhuang;
	Kapian(Xingzhuang xingzhuang)
	{
		this.xingzhuang=xingzhuang;
	}
	public Xingzhuang getxingzhuang() 
	{
		return xingzhuang;
	}
	public void setxingzhuang(Xingzhuang xingzhuang) 
	{
		this.xingzhuang=xingzhuang;
	}
}
class Kapianlist//卡片属性
{
	ArrayList<Kapian> kapianList=new ArrayList<Kapian>();
	Kapianlist (ArrayList<Integer> list)
	{
		for(int i=0;i<list.size();i++)
		{
			if(list.get(i)==1)
			{
				double r=Main.input.nextDouble();
				Circle circle=new Circle(r);
				Kapian kapian=new Kapian(circle);
				kapian.getxingzhuang().setKapianName("Circle");
				kapianList.add(kapian);	
			}
			if(list.get(i)==2)
			{
				double w=Main.input.nextDouble();
				double l=Main.input.nextDouble();
				Rectangle rectangle=new Rectangle(w,l);
				Kapian kapian=new Kapian(rectangle);
				kapian.getxingzhuang().setKapianName("rectangle");
				kapianList.add(kapian);	
			}
			if(list.get(i)==3)
			{
				double x=Main.input.nextDouble();
				double y=Main.input.nextDouble();
				double z=Main.input.nextDouble();
				Triangle triangle=new Triangle(x,y,z);
				Kapian kapian=new Kapian(triangle);
				kapian.getxingzhuang().setKapianName("triangle");
				kapianList.add(kapian);	
			}
			if(list.get(i)==4)
			{
				double x=Main.input.nextDouble();
				double y=Main.input.nextDouble();
				double z=Main.input.nextDouble();
				Trapezoid traperoid=new Trapezoid(x,y,z);
				Kapian kapian=new Kapian(traperoid);
				kapian.getxingzhuang().setKapianName("Trapezoid");
				kapianList.add(kapian);	
			}
		}
	}
			public boolean check() 
			{
				for(int i=0;i<kapianList.size();i++)
					{
						if(!kapianList.get(i).getxingzhuang().check())
						{
							return false;
						}
					}
				return true;
			}
			public void KapianSort() 
			{
				for(int k=0;k<kapianList.size();k++)
				{
					for(int i=k+1;i<kapianList.size();i++)
					{
						if(kapianList.get(k).getxingzhuang().getArea()<kapianList.get(i).getxingzhuang().getArea())
							Collections.swap(kapianList, k, i);
					}
				
				}
			}
			public double getAllArea() 
			{
				double s=0;
				for(int i=0;i<kapianList.size();i++)
					s=s+kapianList.get(i).getxingzhuang().getArea();
				return s;
			}
			public void showResult() 
			{
				System.out.printf("The original list:\n");
				for(int i=0;i<kapianList.size();i++)
				{
					System.out.print(kapianList.get(i).getxingzhuang().getKapianName()+":");
					System.out.printf("%.2f"+" ",kapianList.get(i).getxingzhuang().getArea());
				}
				System.out.printf("\n");
				System.out.printf("The sorted list:\n");
				KapianSort();
				for(int i=0;i<kapianList.size();i++)
				{
					System.out.print(kapianList.get(i).getxingzhuang().getKapianName()+":");
					System.out.printf("%.2f"+" ",kapianList.get(i).getxingzhuang().getArea());
				}
					System.out.printf("\n");
				System.out.printf("Sum of area:%.2f\n",getAllArea());
			}
}


 

这是一个 SQL 语句,用于向借阅表中插入数据。该表包含以下字段:借阅编号、读者编号、书籍编号、借阅日期、归还日期、借阅状态。每条数据表示一次借阅记录。其中借阅编号、读者编号、书籍编号、借阅日期和借阅状态是必填项,归还日期为可选项,如果借阅状态为“已还”则必须填写归还日期。 具体插入的数据如下: - 借阅编号:100001,读者编号:123413,书籍编号:0001,借阅日期:2020-11-05,归还日期:NULL,借阅状态:借阅 - 借阅编号:100002,读者编号:223411,书籍编号:0002,借阅日期:2020-9-28,归还日期:2020-10-13,借阅状态:已还 - 借阅编号:100003,读者编号:321123,书籍编号:1001,借阅日期:2020-7-01,归还日期:NULL,借阅状态:过期 - 借阅编号:100004,读者编号:321124,书籍编号:2001,借阅日期:2020-10-09,归还日期:2020-10-14,借阅状态:已还 - 借阅编号:100005,读者编号:321124,书籍编号:0001,借阅日期:2020-10-15,归还日期:NULL,借阅状态:借阅 - 借阅编号:100006,读者编号:223411,书籍编号:2001,借阅日期:2020-10-16,归还日期:NULL,借阅状态:借阅 - 借阅编号:100007,读者编号:411111,书籍编号:1002,借阅日期:2020-9-01,归还日期:2020-9-24,借阅状态:已还 - 借阅编号:100008,读者编号:411111,书籍编号:0001,借阅日期:2020-9-25,归还日期:NULL,借阅状态:借阅 - 借阅编号:100009,读者编号:411111,书籍编号:1001,借阅日期:2020-10-08,归还日期:NULL,借阅状态:借阅
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值