喷头装置(一)

本文探讨了如何使用贪心算法解决喷头装置设计中的问题,通过参考两篇优快云博客文章,深入理解算法在实际工程中的应用。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

http://blog.youkuaiyun.com/dingsai88/article/details/51179187

http://blog.youkuaiyun.com/hongkangwl/article/details/12706935?utm_source=jiancool

参考上面文章,用到贪心算法



import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.util.Arrays;
import java.util.Scanner;

public class hh {

	public static void main(String[] args) throws IOException {
		BufferedReader strin = new BufferedReader(new InputStreamReader(System.in));
		String[] radius;
		System.out.println("请输入测试组数");
		int n = Integer.parseInt(strin.readLine());
		int num = 1;
		while (n > 0) {
			System.out.println("请输入第" + (num) + "组喷头数目");
			int count = Integer.parseInt(strin.readLine());
			System.out.println("请输入第" + (num) + "组喷头半径");
			String ss = strin.readLine();
			radius = ss.split(" ");
			Arrays.sort(radius);
			int result = col(radius);
			System.out.println("第" + num + "组最少需要喷头" + result + "个");
			num++;
			n--;
		}

	}

	private static int col(String[] radius) {
		double sum = 0;
		int num = 0;
		for (int i = radius.length - 1; i > 0; i--) {
			double n = Double.parseDouble(radius[i]);
			sum += 2 * Math.sqrt(n * n - 1);
			if (sum >= 20) {
				return i + 1;
			}
		}
		return radius.length;

	}
}


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值