解题思路:

注意事项:

参考代码:

import java.util.Scanner;

public class Main {

	/**
	 * @param args
	 */
	public static void main(String[] args) {
		// TODO Auto-generated method stub
		/*
		 * 译文1111:圆柱体
		 * 
		 * 时间限制:1秒内存限制:128MB提交:1635解决:638
		 * 
		 * 译文描述 使用纸和剪刀,您可以通过以下方式切出两个面以形成圆柱体:
		 * 
		 * 
		 * 水平切纸(平行于较短边)以得到两个矩形部分。
		 * 
		 * 从第一部分开始,切出一个最大半径的圆。圆圈将形成圆柱体的底部。
		 * 
		 * 卷起第二部分,使其周长与圆的周长相等,然后将卷的一端连接到圆上。请注意,卷筒可能会有一些重叠的部分,以便获得所需的周长。
		 * 
		 * 在给定纸张尺寸的情况下,您可以计算出可以使用上述步骤构造的最大量的圆柱体吗?
		 * 
		 * 输入 输入包含几个测试用例。每个测试用例均由两个数字w和h(1≤w≤h≤100)组成,分别表示纸张的宽度和高度。
		 * 
		 * 最后一个测试用例后面是包含两个零的行。
		 * 
		 * 输出 对于每个测试用例,请打印出一行,并以最大的气缸容量来打印。将此数字四舍五入到小数点后3位。
		 * 
		 * 样例输入 10 10 10 50 10 30 0 0
		 * 
		 * 样例输出 54.247 785.398 412.095
		 */
		Scanner scanner = new Scanner(System.in);

		double w, h, r, result1, result2;

		double PI = 3.141592653589793238;
		while (scanner.hasNext()) {
			w = scanner.nextDouble();
			h = scanner.nextDouble();
			if (w == 0 || h == 0) {
				return;
			}
			r = w / (2 * PI);// 第一种情况
			result1 = PI * r * r * (h - 2 * r);
			r = h / (2 * PI + 2);
			r = r * 2 > w ? w / 2 : r;// 第二种情况
			result2 = PI * r * r * w;
			System.out.println(String.format("%.3f",
					result1 > result2 ? result1 : result2));
		}// 输出两种情况算出来的最大者即可

	}

}


点赞(0)
 

0.0分

3 人评分

C语言网提供由在职研发工程师或ACM蓝桥杯竞赛优秀选手录制的视频教程,并配有习题和答疑,点击了解:

一点编程也不会写的:零基础C语言学练课程

解决困扰你多年的C语言疑难杂症特性的C语言进阶课程

从零到写出一个爬虫的Python编程课程

只会语法写不出代码?手把手带你写100个编程真题的编程百练课程

信息学奥赛或C++选手的 必学C++课程

蓝桥杯ACM、信息学奥赛的必学课程:算法竞赛课入门课程

手把手讲解近五年真题的蓝桥杯辅导课程

评论列表 共有 0 条评论

暂无评论