问题 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 2016-08-23 12:03  椿和湫  阅读(235)  评论(0编辑  收藏  举报

导航