牛客NC235817

题意:

题干:https://ac.nowcoder.com/acm/problem/235817 来源:牛客网

给定一片 n×mn\times mn×m 海域的洋流地图,其中每一个位置都有一个洋流。每次你可以向北、东北、东、东南、南、西南、西或者西北移动,并且不能离开这片海域。如果你当前坐标是 (x,y)(x,y)(x,y) ,按照上述方向移动后,你分别能达到坐标 (x−1,y)(x-1,y)(x−1,y) 、 (x−1,y+1)(x-1,y+1)(x−1,y+1) 、 (x,y+1)(x,y+1)(x,y+1) 、 (x+1,y+1)(x+1,y+1)(x+1,y+1) 、 (x+1,y)(x+1,y)(x+1,y) 、 (x+1,y−1)(x+1,y-1)(x+1,y−1) 、 (x,y−1)(x,y-1)(x,y−1) 和 (x−1,y−1)(x-1,y-1)(x−1,y−1) 。当你顺着洋流走时不消耗体力,否则你需要消耗1点体力。现给出 TTT 组询问,每组询问需要你回答从坐标 (x1,y1)(x_1,y_1)(x1,y1) 到 (x2,y2)(x_2,y_2)(x2,y2) 最少消耗多少体力。

思路:

一开始以为是bfs模板题,直接做可以通过样例但是会超时,考虑到搜索的优先度,应该是对于已经标记的点中选择最少的去遍历,于是选用deque这种双向开口的容器进行搜索,符合洋流方向的不必消耗,可以放在队头接着搜索,其他和普通的bfs相同。

代码:

tips:好像用emplace_back 会比push_back 更高效。C++ emplace_back - 简书 (jianshu.com)

### NC200369 四舍五入 解题思路 对于给定的小数字符串,需要按照指定的次数 `t` 进行四舍五入操作。每次四舍五入都是基于当前最右边的一位小数来决定是否进位。 #### 思路分析 1. **初始化处理** - 首先读取输入数据并解析成可操作的形式。 - 将原始分数转换为字符列表以便逐位修改[^2]。 2. **核心逻辑** - 对于每一次四舍五入: - 如果当前位置小于等于4,则直接截断后续部分; - 若大于等于5则向前一位加一,并继续检查前一位是否会再次触发进位直到不再发生为止。 - 更新剩余需处理的有效位数计数器 `t`,当其减至零时停止循环。 3. **特殊情况考虑** - 当所有有效数字都被处理完毕但仍存在未完成的四舍五入需求时,在结果前面补上相应数量的'1'。 #### 代码实现 以下是 Python 实现: ```python def round_number(n, t, num_str): # 转换为list方便操作 nums = list(num_str) dot_index = nums.index('.') start_pos = dot_index + min(t, len(nums) - 1) while t > 0 and '.' not in str(start_pos): current_digit = int(nums[start_pos]) if current_digit >= 5: carry = True for i in range(start_pos - 1, -1, -1): if nums[i].isdigit(): next_digit = (int(nums[i]) + 1) % 10 if next_digit != 0 or i == 0: carry = False nums[i] = str(next_digit) break if carry: nums.insert(0, '1') del nums[start_pos:] t -= 1 try: start_pos = max(dot_index + min(t, len(nums) - dot_index - 1), 0) except ValueError as e: pass result = ''.join([str(x) for x in nums]).rstrip('0').rstrip('.') or "0" return result if __name__ == "__main__": n, t = map(int, input().split()) initial_score = input() print(round_number(n, t, initial_score)) ```
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爱吃芒果的蘑菇

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值