题解 P3717 【[AHOI2017初中组]cover】

简介: 题目链接 本题的大致思路就是搜索。将矩阵初始化成false。先把灯塔标记。在搜一遍灯塔能照到的点并标记。最后搜一遍找被灯塔标记的个数。详细解释见题解。题解走起。 #include using namespace std; bool a[1001][1001]; //数组开的有点大哈,开到200就足够了。

题目链接

本题的大致思路就是搜索。

将矩阵初始化成false。先把灯塔标记。在搜一遍灯塔能照到的点并标记。最后搜一遍找被灯塔标记的个数。

详细解释见题解。

题解走起。

#include<bits/stdc++.h>
using namespace std;
bool a[1001][1001];                                  //数组开的有点大哈,开到200就足够了。不过想要标记,就要是bool型的。
int main()
{
    int n,m,r,sum=0;                                 //sum为后面用的计数器。
    int j=0,k=0,i=0;
    int x,y;                                           //i,j,k,x,y作为控制循环次数的东东。
    cin>>n>>m>>r;                                    //输入数据
    for(i=0;i<m;i++)                                 //第一遍标记###看好括号###
    {
        cin>>j>>k;                                   //对于每一个灯塔的坐标进行输入
        a[j-1][k-1]=1;                               //标记灯塔位置
                                                     /*这里要说一点,灯塔坐标给的和数组定义的不太一样。
                                                       数组的0是第一位。而灯塔的坐标是从1开始的,所以要将坐减一。
                                                       我第一次就是这么被坑的。*/
        for(x=0;x<n;x++)                             //第一次搜索开始
        {   for(y=0;y<n;y++)
            {
              if((x-j+1)*(x-j+1)+(y-k+1)*(y-k+1)<=r*r)//圆的方程:(x-a)²+(y-b)²=r²
              {
                  a[x][y]=1;                         //标记被搜到的。
              }
            }
        }                                            //说实话这个括号和上面“第二次搜索开始“后面的都不用加。
                                                     //为了清楚,我现在加上了。
    }                                                //好了,现在搜完第一次了
                                                     //开始统计。第二次搜索,并计数
    for(i=0;i<n;i++)                                 //全图走一遍。
    {   for(j=0;j<n;j++)
        {
            if(a[i][j]==1)
            {
                sum++;
            }
        }   
    }
    cout<<sum;                                       //输出
    return 0;                                        //程序拜拜。
}

 

相关文章
|
7月前
|
C++
【洛谷 P1923】【深基9.例4】求第 k 小的数 题解(nth_element)
该题目要求输入一个奇数个整数 $n$($1 \le n &lt; 5000000$)和一个位置 $k$,在给定的 $n$ 个不超过 ${10}^9$ 的整数中找出第 $k$ 小的数。样例输入为 `5 1` 和 `4 3 2 1 5`,输出第 $1$ 小的数,即 `2`。解决方案使用 C++ 的 `nth_element` 函数来找到第 $k$ 小的数。
57 0
light oj 1231-1232 - 1233- Coin Change 背包
暂时到半懂不懂也没办法讲明白,就不误人子弟了,直接贴代码了。
38 0
|
机器学习/深度学习 人工智能
P4447 [AHOI2018初中组]分组 详解
小可可的学校信息组总共有n 个队员,每个人都有一个实力值a[i]a[i]。现在,一年一度的编程大赛就要到了,小可可的学校获得了若干个参赛名额,教练决定把学校信息组的nn 个队员分成若干个小组去参加这场比赛。 但是每个队员都不会愿意与实力跟自己过于悬殊的队员组队,于是要求分成的每个小组的队员实力值连续,同时,一个队不需要两个实力相同的选手。举个例子:[1, 2, 3, 4, 5]是合法的分组方案,因为实力值连续;[1, 2, 3, 5]不是合法的分组方案,因为实力值不连续;[0,1,1,2]同样不是合法的分组方案,因为出现了两个实力值为1 的选手。 如果有小组内人数太少,就会因为时间
337 1
|
机器学习/深度学习 人工智能 算法
每日一题冲刺大厂第十六天提高组 codeforces 783 div1 Half Queen
大家好,我是泡泡,给大家带来每日一题的目的是为了更好的练习算法,我们的每日一题提高组是为了有余力的同学准备的,让大家练到各种各样的题目,一年以后,蜕变成为一个不一样的自己!
123 0
每日一题冲刺大厂第十六天提高组 codeforces 783 div1 Half Queen
洛谷P1216-[USACO1.5][IOI1994]数字三角形 Number Triangles(DP)
洛谷P1216-[USACO1.5][IOI1994]数字三角形 Number Triangles(DP)
洛谷P1216-[USACO1.5][IOI1994]数字三角形 Number Triangles(DP)
洛谷P2722-[USACO3.1]总分 Score Inflation(完全背包)
洛谷P2722-[USACO3.1]总分 Score Inflation(完全背包)
洛谷P2722-[USACO3.1]总分 Score Inflation(完全背包)