吾爱破解 - 52pojie.cn

 找回密码
 注册[Register]

QQ登录

只需一步,快速开始

查看: 1076|回复: 3
收起左侧

[已解决] CCF 201909-1小明种苹果 Python

[复制链接]
一条孤独的狗 发表于 2020-4-19 13:53
本帖最后由 一条孤独的狗 于 2020-4-23 22:28 编辑

2个样例的输出都对了,但是得分只有20分,不知道错在哪里
p02.png
[Asm] 纯文本查看 复制代码
N, M = map(int, input().split())
drop = []   #记录每棵树掉了多少苹果
sum = 0     #苹果总数
for i in range(N):
    apple = list(map(int, input().split()))
    each = 0#每棵树剩下的苹果
    each_drop = 0#每棵树掉了多少苹果
    for i in apple:
        each = each + i
        if i < 0:
            each_drop += i
    each_drop = 0 - each_drop
    drop.append(each_drop)
    sum += each
k = 0
for i in range(N - 1):
    if drop[i + 1] > drop[i]:
        k = i + 1
print(sum, k + 1, drop[k])

发帖前要善用论坛搜索功能,那里可能会有你要找的答案或者已经有人发布过相同内容了,请勿重复发帖。

空想昼夜 发表于 2020-4-23 20:28
emmmm 好久没看算法题了

楼主这里17行的判断条件写错了

取极值怎么可能仅考虑相邻的呢

maxcount = 0
for i in range(N-1):
    if drop[i+1] > maxcount:
         maxcount = drop[i+1]
         k = i + 1

另外楼主以后发题记得把数据大小也发出来

我看这个题是第一题  应该没什么坑  如果是后面的话  不同数据范围的算法也不一样

免费评分

参与人数 1吾爱币 +1 热心值 +1 收起 理由
一条孤独的狗 + 1 + 1 谢谢@Thanks!

查看全部评分

 楼主| 一条孤独的狗 发表于 2020-4-23 22:24
谢谢解惑,我把drop[k]写成了drop[i],还一直没发现
for i in range(N - 1):
    if drop[i + 1] > drop[k]:
        k = i + 1


 楼主| 一条孤独的狗 发表于 2020-4-23 22:27
一条孤独的狗 发表于 2020-4-23 22:24
谢谢解惑,我把drop[k]写成了drop,还一直没发现
for i in range(N - 1):
    if drop > drop[k]:

去年考CCF的时候,第一题只得了20分,我还一直找不到答案
前几天重新做的时候,又是20分,心态崩了
原来是这么简单的一个错误,亏我找了那么久
非常感谢你!
您需要登录后才可以回帖 登录 | 注册[Register]

本版积分规则

返回列表

RSS订阅|小黑屋|处罚记录|联系我们|吾爱破解 - LCG - LSG ( 京ICP备16042023号 | 京公网安备 11010502030087号 )

GMT+8, 2024-11-26 18:37

Powered by Discuz!

Copyright © 2001-2020, Tencent Cloud.

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