CCF-CSP 201912-2回收站选址

本文深入探讨了一种针对回收站选址的算法实现,通过遍历垃圾位置并检查周围区域,来统计不同条件下的回收站数量。该算法使用C++编写,涉及数据结构如map和pair的应用,以及条件判断和计数的逻辑处理。

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

回收站选址

#include <bits/stdc++.h>
using namespace std;

int ans[6];
map <pair<int , int>, int> g;//垃圾的位置
int main() {
    int n;
    scanf("%d", &n);
    for (int i = 0; i < n; i++){
        int x, y;
        scanf("%d%d", &x, &y);
        g[{x, y}] = 1;
    }
    for (auto _ : g){
        int x = _.first.first;
        int y = _.first.second;
        if (g[{x, y}] ==1){
            if (g[{x + 1, y}] == 1 && g[{x, y + 1}] == 1 && g[{x - 1, y}] == 1 && g[{x, y - 1}] == 1){
                int cnt = 0;
                if (g[{x + 1, y + 1}] == 1) cnt++;
                if (g[{x - 1, y - 1}] == 1) cnt++;
                if (g[{x + 1, y - 1}] == 1) cnt++;
                if (g[{x - 1, y + 1}] == 1) cnt++;
                ans[cnt]++;
            }
        }
    }
    for (int i = 0; i < 5; i++){
        printf("%d\n", ans[i]);
    }
    return 0;
}

/*

*/

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值