问题 A: 喷水装置(一)

题目描述

现有一块草坪,长为20米,宽为2米,要在横中心线上放置半径为Ri的喷水装置, 每个喷水装置的效果都会让以它为中心的半径为实数Ri(0<Ri<15)的圆被湿润,这有充足的喷水装置i(1<i<600) 个,并且一定能把草坪全部湿润,你要做的是:选择尽量少的喷水装置,把整个草坪的全部湿润。

输入

第一行m表示有m组测试数据
每一组测试数据的第一行有一个整数数n,n表示共有n个喷水装置,随后的一行,有n个实数ri,ri表示该喷水装置能覆盖的圆的半径。

输出

输出所用装置的个数

样例输入

2
5
2 3.2 4 4.5 6 
10
1 2 3 1 2 1.2 3 1.1 1 2

样例输出

2
5
复制代码
 1 #include<stdio.h>
 2 #include<math.h>
 3 #define N 600
 4 float a[N];
 5 
 6 int main( ) {
 7     int m, sum, i, j;
 8     float temp, l;
 9     scanf("%d", &m);
10     while(m--) {
11         int n;
12         scanf("%d", &n);
13         for(i = 0; i < n; i ++)
14             scanf("%f", &a[i]);
15         for(i = 0; i < n; i ++) //从小到大排序(冒泡排序)
16             for(j = i + 1; j < n;j ++)
17                 if(a[i] > a[j]) {
18                     temp = a[i];
19                     a[i] = a[j];
20                     a[j] = temp;
21                 }
22                 l = 20;
23                 sum = 0;
24                 for(i = n - 1; l >= 0; i--) {
25                     l = l - 2 * sqrt(a[i] * a[i] - 1);
26                     sum ++;
27                 }
28                 printf("%d\n", sum);
29     }
30     return 0;
31 }
View Code
复制代码

 

posted on   椿和湫  阅读(236)  评论(0编辑  收藏  举报

编辑推荐:
· 深入理解 Mybatis 分库分表执行原理
· 如何打造一个高并发系统?
· .NET Core GC压缩(compact_phase)底层原理浅谈
· 现代计算机视觉入门之:什么是图片特征编码
· .NET 9 new features-C#13新的锁类型和语义
阅读排行:
· Spring AI + Ollama 实现 deepseek-r1 的API服务和调用
· 《HelloGitHub》第 106 期
· 数据库服务器 SQL Server 版本升级公告
· 深入理解Mybatis分库分表执行原理
· 使用 Dify + LLM 构建精确任务处理应用
< 2025年1月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8

导航

统计

点击右上角即可分享
微信分享提示