鱼C论坛

 找回密码
 立即注册
查看: 276|回复: 8

大佬们,帮我看看呗,第九讲作业为什么这样写是不对的?

[复制链接]
发表于 2025-3-6 20:21:12 From FishC Mobile | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 爱吃菠萝包 于 2025-3-6 20:40 编辑

相传国际象棋是古印度舍罕王的宰相达依尔发明的。
舍罕王十分喜爱国际象棋,便决定让宰相自己选择何种赏赐。这位聪明的宰相指着 8×8 共 64 格的象棋棋盘说:陛下,请您赏给我一些麦子吧。就在棋盘的第 1 格中放 1 粒,第 2 格放 2 粒,第 3 格放 4 粒,以后每一格都比前一格增加一倍,依此放完棋盘上 64 格,我就感激不尽了……
舍罕王听了达依尔这个“小小”的要求,便让人扛来一袋麦子,他要兑现许诺。结果,在给达依尔发放麦子时,舍罕王发现他要给达依尔的麦子比自己想象的要多得多,一袋麦子是远远不够的……

请编程计算舍罕王应该给达依尔多少粒麦子?

i=0      
s=1

while i <= 64:
    wheats=pow(2,i+1)
    s = s + wheats
    i = i + 1

print("舍罕王应该给达依尔", s, "粒麦子!")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2025-3-6 20:21:21 | 显示全部楼层
您给出的代码片段不完整,因此很难指出具体的错误。不过,假设此问题是关于一个 while 循环可能导致的错误,这里有一些常见的检查点:

  • 确保循环条件正确:您只给出了 while i,它会根据 i 的布尔值进行循环。如果 i 不等于零,循环会一直运行。
  • 检查循环的终止条件:确保在循环内 i 或其他影响循环条件的变量被正确更新。
  • 确认循环逻辑:检查实现逻辑是否符合实际需求。


如果您能提供完整的代码和期望的功能,我可以帮助您更具体地分析!

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2025-3-6 21:30:31 | 显示全部楼层
第 1 格(i=0) -> 2 的 0 次方
第 2 格(i=1) -> 2 的 1 次方
……
第 64 格(i=63) -> 2 的 63 次方
i=0
s=0 # 修改
while i < 64: # 修改
    s += pow(2, i) # 修改
    i = i + 1
print("舍罕王应该给达依尔", s, "粒麦子!")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 1 反对 0

使用道具 举报

发表于 2025-3-6 21:52:15 | 显示全部楼层
本帖最后由 jackz007 于 2025-3-6 21:59 编辑
i=0      
s=0

while i < 64:                                 # (0 <= i <= 63) 这样才会循环 64 次
    wheats=pow(2,i)                           # 指数(i)的变化范围应该是 0 - 63
    s = s + wheats
    i = i + 1

print("舍罕王应该给达依尔", s, "粒麦子!")

        这样也是一样的
i=1      
s=1

while i < 64:
    wheats=pow(2,i)
    s = s + wheats
    i = i + 1

print("舍罕王应该给达依尔", s, "粒麦子!")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2025-3-6 22:04:03 | 显示全部楼层
本帖最后由 lianglizhi 于 2025-3-6 22:08 编辑

代码中存在三个主要错误:

循环次数过多:循环条件i <= 64导致执行了65次(i从0到64),而国际象棋棋盘只有64格,应循环64次。

指数计算错误:每格的麦粒数应为2^i(i从0开始),但代码中使用了pow(2, i+1)导致指数偏移。

初始值错误:s=1的初始化会导致重复累加第1格的麦粒,正确应初始化为0。

正确代码

s = 0
i = 0

while i < 64:
    wheats = pow(2, i)
    s += wheats
    i += 1

print("舍罕王应该给达依尔", s, "粒麦子!")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2025-3-6 22:04:37 | 显示全部楼层
lianglizhi 发表于 2025-03-06 22:04
@FishC
问题描述
元宵节到了,小蓝决定举办一场热闹 ...


问题解析与解答思路

问题描述中,小蓝的朋友们具有各自的“元宵节参与度”,且相互之间存在熟悉规则:若两个朋友的参与度差小于某个数值 k,则两个朋友彼此熟悉。

解题思路如下:
1. 我们需要找出所有好友对,使得他们的参与度相差小于 k
2. 记住,你需要对每个好友进行两两比较以确定谁与谁熟悉。

实现代码

我们可以使用以下伪代码来实现:
def find_familiar_pairs(friends, k):
    pairs = []
    n = len(friends)
    for i in range(n):
        for j in range(i + 1, n):
            if abs(friends[i] - friends[j]) < k:
                pairs.append((i, j))
    return pairs

# 示例用法
friends = [参与度1, 参与度2, ..., 参与度n]
k = 差值限制
familiar_pairs = find_familiar_pairs(friends, k)
print(familiar_pairs)

在这个代码中:
- friends 是一个列表,存储着每位朋友的参与度。
- k 是指定的熟悉程度差值限制。
- 两层循环检查每一对朋友,通过 abs(friends[i] - friends[j]) < k 判断他们是否熟悉。

这种算法的时间复杂度为 O(n^2),适用于较小规模的问题。

以上回复来自 FishC AI 小助理,如未能正确解答您的问题,请继续追问。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2025-3-9 13:01:17 | 显示全部楼层
i = 1 # i 从 1 开始,第 i 个格子是 2^(i - 1) 粒
s = 0 # 累加计数

while i <= 64: # 1 ~ 64
    wheats = pow(2, i - 1)
    s = s + wheats
    i = i + 1

print("舍罕王应该给达依尔", s, "粒麦子!")
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2025-3-10 11:46:45 | 显示全部楼层
你这样的话第一次就是2的1次方也就是2个麦子了,相当于从2开始加而不是从一开始,所以总共会多加一次,可以把<=64改成<64.还有一种改法,改成s=0开始,pow的改成pow(2,i)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2025-3-10 11:47:56 | 显示全部楼层
lianglizhi 发表于 2025-3-6 22:04
代码中存在三个主要错误:

循环次数过多:循环条件i

这会不会少加了一次第64次的麦子
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-4-3 04:04

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表