【Python】计算游戏得分

一、题目

Kevin and Stuart want to play the 'The Minion Game'.

Game Rules

  • Both players are given the san string S.
  • Both players have to make substrings using the letters of the string S.
  • Stuart has to make words starting with consonants.
  • Kevin has to make words starting with vowels.
  • The game ends when both players have made all possible substrings.

Scoring

A player gets +1 point for each occurrence of the substring in the string S.

For Example:

String S = BANANA

Kevin's vowel beginning word = ANA

Here, ANA occurs twice in BANANA. Hence, Kevin will get 2 Points.

S = BANANA
StuartKevin
WordsScoreWordsScore
B1A3

N

2AN2
BA1ANA2
NA2ANAN1
BAN1ANANA1
NAN1
BANA1

NANA1
BANAN1
BANANA1

Your task is to determine the winner of the game and their score.

Input Format

A single line of input containing the string S.

Note: The string S will contain only uppercase letters:[A - Z]. 

Sample Input

BANANA

Sample Output

Stuart 12

 Note: Vowels are only defined as AEIOU.

二、代码

def minion_game(string):vowels = {'A', 'E', 'I', 'O', 'U'}stuart_score = 0kevin_score = 0for i, char in enumberate(string):if char in vowels:kevin_score += len(string) - ielse:stuart_score += len(string) - iif stuart_score > kevin_score:print("Stuart", stuart_score)elif kevin_score > stuart_score:print("Kevin", kevin_score)else:print("Draw")if __name__ == '__main__':s = input()minion_game(s)

三、解答

for i, char in enumerate(string):

使用 enumerate() 函数遍历字符串 string。

enumerate() 会返回每个字符及其索引(从0开始)。

if char in vowels:kevin_score += len(string) - i
else:stuart_score += len(string) - i

1、如果当前字符 char 是元音(在 vowels 集合中),则计算 kevin_score 。由于每个元音字符都可以作为以子字符串的其实字符,Kevin 获得的分数是剩余字符串长度 (len(string) - i)

2、如果当前字符不是元音(即辅音),则计算 stuart_score。 同样,由于每个辅音字符都可以作为以辅音开头的子字符串的起始字符,Stuart 获得的分数是剩余字符串长度。

if stuart_score > kevin_score:print("Stuart", stuart_score)
elif kevin_score > stuart_score:print("Kevin", kevin_score)
else:print("Draw")

在循环结束后,比较 stuart_score 和 kevin_score。 如果 Stuart 的得分更高,打印 "Stuart" 和得分;如果 Kevin 的得分更高,打印 "Kevin" 和得分;如果两者得分相同,打印 "Draw"。

 四、enumerate()

enumerate() 函数在 Python 中是一个内置函数,它的作用是将一个可迭代对象(如列表、元组、字符串等)组合为一个索引序列,同时返回元素和它的索引。在工作中,enumerate() 可以带来以下好处:

1、方便迭代:在遍历列表或其他序列时,enumerate() 允许你同时获得元素的索引和值,这使得处理元素时可以更方便地引用其位置。

2、索引访问:当你需要在循环中使用元素的索引时(例如,作为字典的键或在另一个列表中访问元素),enumerate() 提供了一个简洁的方式来做到这一点。

3、代码可读性:使用 enumerate() 可以使代码更加清晰和易于理解,因为你不需要手动维护一个索引计数器。

4、性能:在某些情况下,使用 enumerate() 可能比手动管理索引更高效,尤其是在处理大型数据集时。

5、功能强大:enumerate() 还允许你指定起始索引,如果你想从非零索引开始计数,这非常有用。

示例:

for index, value in enumerate(['a', 'b', 'c']):print(index, value)

输出:

0 a

1 b

2 c

  • 在这个示例中, enumerate() 同时提供了列表中每个元素的索引(index)和值(value),使得遍历和处理变得非常简单。
  • 在工作中,enumerate() 特别使用于需要跟踪元素位置或需要根据元素位置执行不同操作的场景。例如,在处理文件中的数据行时,你可能需要知道当前处理的是第几行数据,这时使用 enumerate() 就非常方便。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/pingmian/51263.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

Could not find a package configuration file provided by “catkin_simple“ 的参考解决方法

文章目录 写在前面一、问题描述二、解决方法参考链接 写在前面 自己的测试环境: Ubuntu20.04 ROS-Noetic 一、问题描述 CMake Error at /***/CMakeLists.txt:4 (find_package):By not providing "Findcatkin_simple.cmake" in CMAKE_MODULE_PATH thisp…

vue项目启动报错 vue与vue-template-compiler版本不一致

出现错误 Vue packages version mismatch: vue2.6.12 (/Users/work_ws/project/my/astar-education/astar-education-ui/node_modules/vue/dist/vue.runtime.common.js)vue-template-compiler2.6.13 (/Users/work_ws/project/my/astar-education/astar-education-ui/node_mod…

图中的最短环

2608. 图中的最短环 现有一个含 n 个顶点的 双向 图,每个顶点按从 0 到 n - 1 标记。图中的边由二维整数数组 edges 表示,其中 edges[i] [ui, vi] 表示顶点 ui 和 vi 之间存在一条边。每对顶点最多通过一条边连接,并且不存在与自身相连的顶…

Hive——UDF函数:高德地图API逆地理编码,实现离线解析经纬度转换省市区(离线地址库,非调用高德API)

文章目录 1. 需求背景数据现状业务需求面临技术问题寻求其他方案 2. 运行环境软件版本Maven依赖 3. 获取离线地址库4. Hive UDF函数实现5. 创建Hive UDF函数6. 参考 1. 需求背景 数据现状 目前业务系统某数据库表中记录了约3亿条用户行为数据,其中两列记录了用户触…

Java1.2标准之重要特性及用法实例(十三)

简介: CSDN博客专家,专注Android/Linux系统,分享多mic语音方案、音视频、编解码等技术,与大家一起成长! 新书发布:《Android系统多媒体进阶实战》🚀 优质专栏: Audio工程师进阶系列…

SciPy 与 MATLAB 数组

SciPy 与 MATLAB 数组 SciPy 是一个开源的 Python 库,广泛用于科学和工程计算。它构建在 NumPy 数组的基础之上,提供了许多高级科学计算功能。MATLAB 是一个高性能的数值计算环境,它也使用数组作为其基础数据结构。在这篇文章中,我们将探讨 SciPy 和 MATLAB 在数组操作上的…

征服 Docker 镜像访问限制:KubeSphere v3.4.1 成功部署全攻略

近期,KubeSphere 社区的讨论中频繁出现关于 Docker 官方镜像仓库访问受限的问题。 本文旨在为您提供一个详细的指南, 展示在 Docker 官方镜像访问受限的情况下,如何通过 KubeKey v3.1.2 一次性成功部署 KubeSphere v3.4.1 以及 Kubernetes …

深入剖析:GaussDB与MySQL在COUNT查询中的并行化技术

引言 数据库查询性能优化是数据库管理和开发中的一个重要议题。在处理大数据量的COUNT查询时,传统的单线程处理方式可能无法满足现代应用的性能需求。GaussDB(for MySQL)和MySQL作为流行的数据库系统,它们在并行查询优化方面有着各自的策略和技术。本文…

Python批量采集某东评论,实现可视化分析

女朋友没事就喜欢网购,买一大堆又不用,总说不合适,为了不让她花冤枉钱,于是我决定用Python写一个采集商品评论的脚本,然后对商品进行分析,这样就不怕踩到坑了! 让我们直接开始本次操作 准备工作…

Python及Jupyter-Notebook安装

来源: “码农不会写诗”公众号 链接:Python及Jupyter-Notebook安装 文章目录 01 Python安装1.1 下载安装包1.2 双击安装包,开始安装1.3 选择安装配置1.4 选择需要安装的Optional Feature,点击Next1.5 选择需要安装的Advanced Feat…

Apache DolphinScheduler Worker Task执行原理解析

大家好,我是蔡顺峰,是白鲸开源的高级数据工程师,同时也是Apache DolphinScheduler社区的committer和PMC member。今天我要分享的主题是《Worker Task执行原理》。 整个分享会分为三个章节: Apache DolphinScheduler的介绍Apache …

Python3网络爬虫开发实战(3)网页数据的解析提取

文章目录 一、XPath1. 选取节点2. 查找某个特定的节点或者包含某个指定的值的节点3. XPath 运算符4. 节点轴5. 利用 lxml 使用 XPath 二、CSS三、Beautiful Soup1. 信息提取2. 嵌套选择3. 关联选择4. 方法选择器5. css 选择器 四、PyQuery1. 初始化2. css 选择器3. 信息提取4. …

一步步理清开源路径规划导航引擎GraphHopper

一步步理清开源路径规划导航引擎GraphHopper,学习应用 GraphHopper简介 源码用 Java 编写,开发人员可以通过 Maven 轻松上手。可以用作** Java 库**来计算两个或多个点之间路线的距离、时间、逐向指示和许多道路属性。可以用作独立的 Web 服务器来计算…

CLI是命令行界面(Command-Line Interface)的缩写

CLI是命令行界面(Command-Line Interface)的缩写。它是一种用户界面,允许用户通过键盘输入文本命令来与计算机进行交互。CLI在图形用户界面(GUI)普及之前是最常用的用户界面类型。 CLI的特点: 高效性&…

CentOS下原生态安装mysql,推荐yum

mysql 是一个关系型数据库管理系统,是最流行的关系型数据库管理系统之一,本文将介绍如何在 CentOS 7.x 中安装 mysql 。 安装mysql mysql 的安装方法可以通过以下几种方式进行: 1、通过第三方面板安装 mysql 2、通过 yum 命令安装 mysql 3、…

计算R velocity的方法和流程(CellRank2)

愿武艺晴小朋友一定得每天都开心 第一步:拿到cellranger count的文件夹; 运行cellranger count(这个得提前准备:R1和R2的fastq.gz文件 & 鼠的参考基因组文件) wget https://cf.10xgenomics.com/supp/cell-exp/refdata-gex-mm10-2020-A.tar.gz 最后会出现这个:Pipes…

C++简单实现消息队列

简介 消息队列是一种应用间的通讯方式,消息发送后可以立即放回,由消息系统来确保消息的可靠传递。消息发布者只需要将消息发布到消息队列中,而不需要管谁来取。消息使用者只管从消息队列中取消息而不管谁发布的。这样发布者和使用者都不同知…

uniapp文件上传前后端代码展示

使用uniapp做文件上传的时候&#xff0c;可以使用系统提供的接口进行文件上传 前端部分 前端组件代码 使用的是uview的上传组件 <u-upload id"selectPhoto" :style"{display:selectPhotoDisplay}" :useBeforeRead"true"afterRead"aft…

21.发布确认模式-高级

问题 生产环境中由于一些不明原因&#xff0c;导致rabbitmq重启&#xff0c;在重启的期间生产者消息投递失败&#xff0c;导致消息丢失&#xff0c;需要手动处理恢复。那么如何才能进行rabbitmq的消息可靠性投递&#xff1f;特别是在极端的情况&#xff0c;rabbitmq集群不可用…