Problem Description
定义接口Shape,定义求周长的方法length()。
定义如下类实现接口Shape的抽象方法:
(1)三角形类Triangle (2)长方形类Rectangle (3)圆形类Circle等。
定义测试类ShapeTest,用Shape接口定义变量shape,用其指向不同类形的对象,输出各种图形的周长。并为其他的Shape接口实现类提供良好的扩展性。
Input
输入多组数值型数据(double);
一行中若有1个数,表示圆的半径;
一行中若有2个数(中间用空格间隔),表示长方形的长度、宽度。
一行中若有3个数(中间用空格间隔),表示三角形的三边的长度。
若输入数据中有负数,则不表示任何图形,周长为0。
Output
行数与输入相对应,数值为根据每行输入数据求得的图形的周长(保留2位小数)。
Sample Input
1 2 3 4 5 6 2 -2 -2 -3
Sample Output
6.28 10.00 15.00 12.56 0.00 0.00
Hint
构造三角形时要判断给定的三边的长度是否能组成一个三角形,即符合两边之和大于第三边的规则;
计算圆周长时PI取3.14。
import java.util.Scanner;
public class Main {
public static void main(String args[]) {
Scanner in = new Scanner(System.in);
double l, r, q;
int i;
String s;
while(in.hasNextLine())
{
l = r = q = 0;
s = in.nextLine();
char a[] = s.toCharArray();
for(i = 0; i < a.length; i++)
{
if(a[i] == '-')
{
break;
}
}
if(i < a.length)
{
System.out.println("0.00");
continue;
}
for(i = 0; i < a.length; i++)
{
if(a[i] == ' ')
{
break;
}
l *= 10;
l += a[i] - '0';
}
for(i++; i < a.length; i++)
{
if(a[i] == ' ')
{
break;
}
r *= 10;
r += a[i] - '0';
}
for(i++; i < a.length; i++)
{
if(a[i] == ' ')
{
break;
}
q *= 10;
q += a[i] - '0';
}
if(l != 0 && r == 0 && q == 0)
{
System.out.printf("%.2f\n", 6.28 * l);
}
else if(l != 0 && r != 0 && q == 0)
{
System.out.printf("%.2f\n", 2 * (r + l));
}
else if(l != 0 && r != 0 && q != 0)
{
if(l + r > q && l + q > r && r + q > l)
{
System.out.printf("%.2f\n", r + l + q);
}
else
{
System.out.println("0.00");
}
}
else
{
System.out.println("0.00");
}
}
in.close();
}
}
import java.util.Scanner;
public class Main {
public static void main(String args[]) {
Scanner in = new Scanner(System.in);
double l, r, q;
String s;
while(in.hasNextLine())
{
double len = 0;
s = in.nextLine();
String a[] = s.split(" ");
if(a.length == 1)
{
l = Integer.parseInt(a[0]);
if(l <= 0)
{
len = 0;
}
else
{
len = 6.28 * l;
}
}
else if(a.length == 2)
{
l = Integer.parseInt(a[0]);
r = Integer.parseInt(a[1]);
if(l <= 0 || r <= 0)
{
len = 0;
}
else
{
len = 2 * (l + r);
}
}
else if(a.length == 3)
{
l = Integer.parseInt(a[0]);
r = Integer.parseInt(a[1]);
q = Integer.parseInt(a[2]);
if(l <= 0 || r <= 0 || q <= 0 || l + r <= q || l + q <= r || q + r <= l)
{
len = 0;
}
else
{
len = l + r + q;
}
}
System.out.printf("%.2f\n", len);
}
in.close();
}
}