题解 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;                                        //程序拜拜。
}

 

相关文章
|
8天前
|
人工智能 JSON 供应链
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
LucianaiB分享零成本畅用JVS Claw教程(学生认证享7个月使用权),并开源GeoMind项目——将JVS改造为科研与产业地理情报可视化AI助手,支持飞书文档解析、地理编码与腾讯地图可视化,助力产业关系图谱构建。
23427 9
畅用7个月无影 JVS Claw |手把手教你把JVS改造成「科研与产业地理情报可视化大师」
|
17天前
|
缓存 人工智能 自然语言处理
我对比了8个Claude API中转站,踩了不少坑,总结给你
本文是个人开发者耗时1周实测的8大Claude中转平台横向评测,聚焦Claude Code真实体验:以加权均价(¥/M token)、内部汇率、缓存支持、模型真实性及稳定性为核心指标。
6429 25
|
12天前
|
人工智能 缓存 BI
Claude Code + DeepSeek V4-Pro 真实评测:除了贵,没别的毛病
JeecgBoot AI专题研究 把 Claude Code 接入 DeepSeek V4Pro,跑完 Skills —— OA 审批、大屏、报表、部署 5 大实战场景后的真实体验 ![](https://oscimg.oschina.net/oscnet/up608d34aeb6bafc47f
4153 13
Claude Code + DeepSeek V4-Pro 真实评测:除了贵,没别的毛病
|
13天前
|
人工智能 JSON BI
DeepSeek V4 来了!超越 Claude Sonnet 4.5,赶紧对接 Claude Code 体验一把
JeecgBoot AI专题研究 把 Claude Code 接入 DeepSeek V4Pro 的真实体验与避坑记录 本文记录我将 Claude Code 对接 DeepSeek 最新模型(V4Pro)后的真实体验,测试了 Skills 自动化查询和积木报表 AI 建表两个场景——有惊喜,也踩
4980 13
|
29天前
|
人工智能 自然语言处理 安全
Claude Code 全攻略:命令大全 + 实战工作流(建议收藏)
本文介绍了Claude Code终端AI助手的使用指南,主要内容包括:1)常用命令如版本查看、项目启动和更新;2)三种工作模式切换及界面说明;3)核心功能指令速查表,包含初始化、压缩对话、清除历史等操作;4)详细解析了/init、/help、/clear、/compact、/memory等关键命令的使用场景和语法。文章通过丰富的界面截图和场景示例,帮助开发者快速掌握如何通过命令行和交互界面高效使用Claude Code进行项目开发,特别强调了CLAUDE.md文件作为项目知识库的核心作用。
23217 65
Claude Code 全攻略:命令大全 + 实战工作流(建议收藏)