【蓝桥杯集训·每日一题2025】 AcWing 6122. 农夫约翰的奶酪块 python

ops/2025/2/21 16:12:35/



Week 1
2月17日


农夫约翰的奶酪块

农夫约翰有一块立方体形状的奶酪,它位于三维坐标空间中,从 ( 0 , 0 , 0 ) (0,0,0) (0,0,0) 延伸至 ( N , N , N ) (N,N,N) (N,N,N)

农夫约翰将对他的奶酪块执行一系列 Q Q Q 次更新操作。

对于每次更新操作,农夫约翰将从整数坐标 ( x , y , z ) (x,y,z) (x,y,z) ( x + 1 , y + 1 , z + 1 ) (x+1,y+1,z+1) (x+1,y+1,z+1) 处切割出一个 1 × 1 × 1 1×1×1 1×1×1 的奶酪块,其中 0 ≤ x , y , z < N 0≤x,y,z<N 0x,y,z<N

输入保证在农夫约翰切割的位置上存在一个 1 × 1 × 1 1×1×1 1×1×1 的奶酪块。

由于农夫约翰正在玩牛的世界,当下方的奶酪被切割后,重力不会导致上方的奶酪掉落。

在每次更新后,输出农夫约翰可以将一个 1 × 1 × N 1×1×N 1×1×N 的砖块插入奶酪块中的方案数,使得砖块的任何部分都不与剩余的奶酪重叠。

砖块的每个顶点在全部三个坐标轴上均必须具有整数坐标,范围为 [ 0 , N ] [0,N] [0,N]

农夫约翰可以随意旋转砖块。

输入格式

输入的第一行包含 N N N Q Q Q

以下 Q Q Q 行包含 x x x y y y z z z,为要切割的位置的坐标。

输出格式

在每次更新操作后,输出一个整数,为所求的方案数。

数据范围

2 ≤ N ≤ 1000 2 \le N \le 1000 2N1000,
1 ≤ Q ≤ 2 × 1 0 5 1 \le Q \le 2 \times 10^5 1Q2×105,
0 ≤ x , y , z < N 0 \le x,y,z < N 0x,y,z<N

输入样例:
2 5
0 0 0
1 1 1
0 1 0
1 0 0
1 1 0
输出样例:
0
0
1
2
5
样例解释

在前三次更新操作后, [ 0 , 1 ] × [ 0 , 2 ] × [ 0 , 1 ] [0,1]×[0,2]×[0,1] [0,1]×[0,2]×[0,1] 范围的 1 × 2 × 1 1×2×1 1×2×1 砖块与剩余的奶酪不重叠,因此它贡献了答案。

fig_1_cheese_bronze_dec24.png


思路:

我们需要解决的问题是模拟在三维空间中对奶酪块进行一系列切割操作,并在每次切割后计算可以插入一个 (1 * 1 * N) 砖块的不同方案数

题目解析

  1. 输入格式

    • 第一行包含两个整数 NQ,分别表示奶酪块的大小和更新操作的次数。
    • 接下来的 Q 行每行包含三个整数 x, y, z,表示需要切割的坐标。
  2. 处理逻辑

    • 使用三个二维数组 a, b, c 分别记录在不同维度方向上的切割情况。
      • a[x][y]:记录在第 x 行、第 y 列方向上被切割的次数。
      • b[x][z]:记录在第 x 层、第 z 列方向上被切割的次数。
      • c[y][z]:记录在第 y 层、第 z 行方向上被切割的次数。
    • 在每次切割后,检查是否可以在某个方向上插入一个完整的 1x1xN 砖块(即某个方向上已经被切割了 N 次)。
  3. 输出格式

    • 在每次更新操作后,输出当前可以插入砖块的方案数。

示例解释

对于给定的输入样例:

2 5
0 0 0
1 1 1
0 1 0
1 0 0
1 1 0
  • 第一次切割 (0, 0, 0):没有完整的一维方向被切割,所以方案数为 0
  • 第二次切割 (1, 1, 1):依然没有完整的一维方向被切割,所以方案数仍为 0
  • 第三次切割 (0, 1, 0):现在在 a[0][1] 方向上已经切割了一次,但还未达到 N=2,所以方案数仍为 0
  • 第四次切割 (1, 0, 0):在 b[1][0] 方向上切割了一次,仍未达到 N=2,所以方案数增加到 1
  • 第五次切割 (1, 1, 0):在 c[1][0] 方向上切割了一次,达到了 N=2,因此方案数增加到 5


code:

python">n, q = map(int, input().split()) # 初始化三个二维数组a, b, c来记录每个维度上的切割情况
# a[x][y]表示在x行y列方向上被切割的次数
# b[x][z]表示在x层z列方向上被切割的次数
# c[y][z]表示在y层z行方向上被切割的次数
a = [[0] * n for _ in range(n)]
b = [[0] * n for _ in range(n)]
c = [[0] * n for _ in range(n)]ans = 0  for _ in range(q):x, y, z = map(int, input().split())  # 获取要切割的位置坐标(x, y, z)# 更新对应位置的切割次数a[x][y] += 1b[x][z] += 1c[y][z] += 1# 检查是否可以在某个方向上插入一个完整的1x1xN砖块if a[x][y] == n:  # 如果在x行y列方向上已经完全切割了N次ans += 1if b[x][z] == n:  # 如果在x层z列方向上已经完全切割了N次ans += 1if c[y][z] == n:  # 如果在y层z行方向上已经完全切割了N次ans += 1print(ans)  


END
如果有更多问题或需要进一步的帮助,可以在评论区留言讨论哦!
如果喜欢的话,请给博主点个关注 谢谢


http://www.ppmy.cn/ops/160281.html

相关文章

图解长短期记忆网络(LSTM)

目录 ​编辑 1.长短期记忆网络介绍 2.网络结构 3.模型工作示例 1.长短期记忆网络介绍 在传统的循环神经网络&#xff08;RNN&#xff09;中&#xff0c;神经网络通过循环结构处理序列数据&#xff0c;但存在一个严重的问题&#xff1a;梯度消失和梯度爆炸。这意味着网络很…

鸿道Intewell操作系统:赋能高端装备制造,引领国产数控系统迈向新高度

在当今全球制造业竞争日益激烈的时代&#xff0c;高端装备制造作为国家核心竞争力的重要组成部分&#xff0c;其发展水平直接影响着一个国家的综合实力。而CNC数控系统&#xff0c;作为高端装备制造的“大脑”&#xff0c;对于提升装备的精度、效率和智能化水平起着关键作用。鸿…

如何使用动画和日期差值来切换和展示任务-计划时钟(微信小程序)

微信小程序-计划时钟已上线&#xff0c;欢迎各位小伙伴的测试和使用~&#xff08;微信小程序搜计划时钟即可使用&#xff09; 在这篇博客中&#xff0c;我们将介绍如何使用 JavaScript 和微信小程序的 wx.createAnimation API 来实现基于日期差值的切换动画。我们还会展示如何…

物联网简介集合

物联网&#xff08;IoT&#xff09;指的是物理设备&#xff08;如电器和车辆&#xff09;之间的互联互通。这些设备嵌入了软件、传感器和连接功能&#xff0c;使其能够相互连接并交换数据。这项技术实现了从庞大的设备网络中收集和共享数据&#xff0c;为打造更高效、自动化的系…

5.【线性代数】—— 转置,置换和向量空间

五 转置&#xff0c;置换和向量空间 1. 置换矩阵2. 转置矩阵3. 对称矩阵4. 向量空间4.1 向量空间4.2 子空间 1. 置换矩阵 定义&#xff1a; 用于行互换的矩阵P。 之前进行ALU分解时&#xff0c;可能存在该行主元为0&#xff0c;要进行行互换&#xff0c;即PALU 性质&#xff1…

什么是Embedding、RAG、Function calling、Prompt engineering、Langchain、向量数据库? 怎么使用

什么是Embedding、RAG、Function calling、Prompt engineering、Langchain、向量数据库? 怎么使用 目录 什么是Embedding、RAG、Function calling、Prompt engineering、Langchain、向量数据库? 怎么使用Embedding(嵌入)RAG(检索增强生成)Function calling(函数调用)Pr…

Vue3 定义全局变量

main.js中定义app.config.globalProperties.$test 我是全局变量组件中使用<script setup>import { getCurrentInstance } from vueconst globalProperties getCurrentInstance().appContext.config.globalPropertiesconsole.log(globalProperties.$test) </script&g…

华为动态路由-OSPF-骨干区

华为动态路由-OSPF-骨干区 一、OSPF简介 1、OSPF概述 OSPF是一种开放式的、基于链路状态的内部网关协议&#xff08;IGP&#xff09;&#xff0c;用于在自治系统内部进行路由选择和通信。 OSPF是互联网工程任务组&#xff08;IETF&#xff09;定义的标准之一&#xff0c;被广…