ccf 201803-1 跳一跳(Python实现)
一、原题
问题描述
试题编号: |
201803-1 |
试题名称: |
跳一跳 |
时间限制: |
1.0s |
内存限制: |
256.0MB |
问题描述: |
问题描述 近来,跳一跳这款小游戏风靡全国,受到不少玩家的喜爱。 输入格式 输入包含多个数字,用空格分隔,每个数字都是1,2,0之一,1表示此次跳跃跳到了方块上但是没有跳到中心,2表示此次跳跃跳到了方块上并且跳到了方块中心,0表示此次跳跃没有跳到方块上(此时游戏结束)。 输出格式 输出一个整数,为本局游戏的得分(在本题的规则下)。 样例输入 1 1 2 2 2 1 1 2 2 0 样例输出 22 数据规模和约定 对于所有评测用例,输入的数字不超过30个,保证0正好出现一次且为最后一个数字。 |
二、题解
一般第一题第二题比较简单。这个题利用列表即可。
重点是对当跳到中心计数为2,然后对连续几次需要计数。
三、代码
Python实现:
1 2 3 4 5 6 7 8 9 10 11 12 13 | 以下时 100 分答案: sore,boostsore = 0 , 2 nums = list ( input ().split()) for i in nums: if i = = '1' : sore + = 1 boostsore = 2 elif i = = '2' : sore = sore + boostsore boostsore + = 2 elif i = = '0' : break print (sore) |
可以参考:
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 | 以下时 90 分答案: li = input ().split() sum = 0 a = range ( len (li)) for i in a: if li[i] = = '1' : sum + = 1 i + = 1 elif li[i] = = '2' : n = 2 if i = = 1 : pass else : j = i - 1 while j> = 0 : if li[j] = = '2' : n + = 2 j - = 1 else : break sum + = n i + = 1 print ( sum ) |
本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须在文章页面给出原文连接,否则保留追究法律责任的权利。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
· winform 绘制太阳,地球,月球 运作规律