1974. 使用特殊打字机键入单词的最少时间

关键点:

  1. 无论数组的开头第一位是什么,总是从a开始的,
  2. 从第一个字母向后走的时候有顺时针和逆时针,取最小值
  3. 当从第一个字母开始走的时候,用当前位置替换a的作用
    class Solution:def minTimeToType(self, word: str) -> int:position = 'a'time = 0for char in word:diff = abs(ord(char) - ord(position))step = min(diff, 26-diff)position = chartime += stepreturn (time + len(word))

    函数分析:

  • ord()函数:主要功能是将单个字符转换为其对应的Unicode码点。Unicode是一种字符编码标准,它允许使用相同的代码点来表示全球范围内的字符。

  • abs()函数:求绝对值

  • a = ord('a')
    print(a)  # 97
    b = ord('b')
    y = ord('y')
    print(y)   # 121print(a - y)   # -24
    print(abs(a - y))  # 24
    print(abs(a - b))  # 1

    ascII码,英文字母的差值都是1,Ascii完整码表(256个)_ascii码表-CSDN博客

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

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

相关文章

C#面:请写出C#中的单例模式

单例模式是一种常用的设计模式,它确保一个类只有一个实例,并提供一个全局访问点来访问该实例。 以下是一种常见的C#中的单例模式实现方式: public class Singleton {private static Singleton instance;private static readonly object loc…

实现资产优化管理:智慧校园资产分类功能解析

在构建智慧校园的过程中,细致入微的资产管理是确保教育资源高效运作的关键一环,而资产分类功能则扮演着举足轻重的角色。系统通过精心设计的分类体系,将校园内的各类资产,从昂贵的教学设备到日常使用的办公物资,乃至无…

嵌入式linux系统中动态链接库实现详解

大家好,linux系统中动态库是如何实现相互链接的?今天简单聊聊动态链接库的实现原理。 假设有这样两段代码,第一段代码定义了一个全量变量a以及函数foo,函数foo中引用了下一段代码中定义的全局变量b。 第二段代码定义了全局变量b以及main函数,同时在main函数中调用了第一个…

中英双语介绍美国的州:伊利诺伊州(Illinois)

中文版 伊利诺伊州(Illinois)位于美国中西部,是一个人口众多、经济发达的州。以下是对伊利诺伊州各方面的详细介绍: 发音: IIIinois:英 [ˌɪlɪˈnɔɪ] 人口 截至2020年,美国人口普查数据…

​Chrome插件:React Developer Tools为React开发调试而生

React Developer Tools 是什么? 它是允许在Chrome和Firefox开发者工具中检查React组件层次结构的扩展插件。 插件源码下载 源码下载地址:GitHub - facebook/react-devtools at v3 下载完成以后执行红框中的代码,下载react-devtools 源码,源码如下图所示: 插件打包 当前n…

表单外链,支持查看方式设置

06/19 主要更新模块概览 外链设置 跳转缩放 打印调整 数据校验 01 表单管理 1.1 【表单外链】-填写外链新增查看方式设置 说明: 原表单填写外链,填写字段权限和查看权限统一字段设置,用户在填写时看到数据与查看数据一致…

Qt 使用代码布局,而不使用UI布局

一、工程的建立: 1、打开Qt Creator,文件,新建文件或项目 2、选择Application,Qt Widgets Application 3、写入名称,选择qmake 4、选择基类Base class,去除Generate form 务必选择QWidget,若…

交友系统定制版源码| 相亲交友小程序源码全开源可二开_打造独特的社交交友系统

交友系统源码的实现涉及到多个方面,包括前端页面设计、后端逻辑处理、数据库设计以及用户交互等。以下是一个简单的交友系统源码实现的基本框架和关键步骤: 1.数据库设计:用户表:存储用户基本信息,如用户ID、用户名、密码、头像、性别、年龄、地理位置等…

『手撕Vue-CLI』 添加自定义指令

添加 create 指令 在 vue-cli 中,create 指令是用来创建一个新的项目的,我实现的 nue --help 的帮助信息中只有 --version,--help 这两个指令,所以当用户使用我的 nue-cli 时,并不知道有 create 这个指令,所…

深入解析Apache Flume:定义、架构、原理、应用场景及常用命令

引言 Apache Flume 是一个分布式、可靠且可用的服务,用于高效地收集、聚合和移动大量日志数据。作为一个大数据生态系统的重要组成部分,Flume 可以将数据从各种来源传输到一个集中存储平台,比如 Hadoop HDFS 或 HBase。本文将从 Flume 的定义…

【MySQL】事务实现原理

事务 事务是将一组SQL语句打包成一个整体,在这组SQL的执行过程中,要么全部成功,要么全部失败。这组SQL语句可以是一条也可以是多条。 如果转账成功,应该满足以下要求: 张三的账户余额减少100,变成900&…

C++03 字符串、向量、数组

字符串string 一些初始化string对象的方式: string str; //str是一个空字符串 string str1(str2); // str1是str2的副本 string str1 str2; // 等同于str1(str2) string str("val"); // str是"val"的副本 string str "val"; //等…

FeignClient配置

/***解释 primary 属性的含义:* 作为主要 Bean:* 当 primary 属性设置为 true 时(默认值),Feign 代理将会被标记为主要的 Bean。这意味着,当存在多个同类型的 Bean 时,Spring IoC 容器会优先选择…

Vatee万腾平台:引领行业变革,创新未来

在当今这个快速变化的时代,科技的力量正在以前所未有的速度推动着行业的变革。Vatee万腾平台,以其独特的视角和前瞻性的布局,正引领着行业变革的浪潮,创新着未来的发展方向。 Vatee万腾平台是一家专注于科技研发和创新应用的领军企…

安装PyTorch详细过程(个人过程仅供参考)

1.安装anaconda 2.创建一个虚拟环境 以上步骤默认已经完毕,毕竟只是记录pytorch的安装过程 3.查看个人电脑CUDA版本 winr 输入cmd 回车 输入指令 nvidia-smi 右上角为该电脑所支持的最高CUDA版本 输入命令 nvcc -V 图中即为该电脑所安装的CUDA版本 记住该版…

struct 和 class 的异同

在C编程语言中,struct和class是两个定义数据类型的关键字。尽管它们看起来相似,但它们之间有一些关键的异同。 基本定义 struct struct是从C语言继承而来的,它用于定义一个结构体(structure),结构体是由…

C++编程逻辑讲解step by step:看懂值传递的本质

值传递: 形参是实参的复制品,改变形参的值并不会影响外部实参的值。从被调用函数的角度来说,值传递是单向的(实参->形参),参数的值只能传入,不能传出。当函数内部需要修改参数,并…

C# Winform按钮避免重复点击以及解决WinForm中设置Enabled=False为什么还会响应Click事件

1、C# Winform按钮避免重复点击 代码如下 btn.Enablefalse; //执行任务的函数或代码 btn.Enabletrue; 在btn.Enabletrue前添加Application.DoEvents(); 就是让应用程序的消息队列自动走完(即在按钮为Ture前清空消息队列)。 2、解决WinForm中设置Enabl…

利用 fail2ban 保护 SSH 服务器

利用 fail2ban 保护 SSH 服务器 一、关于 fail2ban1. 基本功能与特性2. 工作原理 二、安装与配置1. Debian/Ubuntu系统:2. CentOS/RHEL系统: 三、保护 SSH四、启动 fail2ban 服务五、测试和验证六、查看封禁的 IP 地址七、一些配置八、注意事项 作者&…

动捕系统如何解决“超出捕捉范围”的挑战

惯性运动捕捉系统改变了我们捕捉运动的方式,使艺术家、创作者和独立工作室能够摆脱动捕实验室和复杂设置的限制。通过身体上的传感器和无线连接,动捕演员可以自由移动和并作出各种高难度动作。然而具有高自由度的惯性动捕系统,经常面临着超出…