当前位置: 首页 > news >正文

神奇字符串、密钥格式化----2023/5/6

神奇字符串----2023/5/6

神奇字符串 s 仅由 ‘1’ 和 ‘2’ 组成,并需要遵守下面的规则:

神奇字符串 s 的神奇之处在于,串联字符串中 ‘1’ 和 ‘2’ 的连续出现次数可以生成该字符串。
s 的前几个元素是 s = “1221121221221121122……” 。如果将 s 中连续的若干 1 和 2 进行分组,可以得到 “1 22 11 2 1 22 1 22 11 2 11 22 …” 。每组中 1 或者 2 的出现次数分别是 “1 2 2 1 1 2 1 2 2 1 2 2 …” 。上面的出现次数正是 s 自身。

给你一个整数 n ,返回在神奇字符串 s 的前 n 个数字中 1 的数目。
示例1:

输入:n = 6
输出:3
解释:神奇字符串 s 的前 6 个元素是 “122112”,它包含三个 1,因此返回 3。 

示例2:

输入:n = 1
输出:1

提示:
1 <= n <= 105

题解1:

class Solution:def magicalString(self, n: int) -> int:if n <= 3:return 1strs = '122'add_str = '1'index, res = 2, 1while len(strs) < n:if len(strs) + int(strs[index]) > n:if add_str == '1':res += int(strs[index])-1else:if add_str == '1':res += int(strs[index])strs += int(strs[index])*add_strindex += 1if add_str == '2':add_str = '1'else:add_str = '2'return res

题解2:参考

class Solution:def magicalString(self, n: int) -> int:s = [1, 2, 2]i = 2while len(s) < n:pre = s[-1]cur = 3 - pre# cur 表示这一组的数字,s[i] 表示这一组数字出现的次数s += [cur] * s[i]i += 1return s[:n].count(1)

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/magical-string
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

密钥格式化----2023/5/6

给定一个许可密钥字符串 s,仅由字母、数字字符和破折号组成。字符串由 n 个破折号分成 n + 1 组。你也会得到一个整数 k 。

我们想要重新格式化字符串 s,使每一组包含 k 个字符,除了第一组,它可以比 k 短,但仍然必须包含至少一个字符。此外,两组之间必须插入破折号,并且应该将所有小写字母转换为大写字母。

返回 重新格式化的许可密钥 。
示例1:

 输入:S = "5F3Z-2e-9-w", k = 4
输出:"5F3Z-2E9W"
解释:字符串 S 被分成了两个部分,每部分 4 个字符;注意,两个额外的破折号需要删掉。

示例2:

输入:S = "2-5g-3-J", k = 2
输出:"2-5G-3J"
解释:字符串 S 被分成了 3 个部分,按照前面的规则描述,第一部分的字符可以少于给定的数量,其余部分皆为 2 个字符。

提示:
1 <= s.length <= 105
s 只包含字母、数字和破折号 ‘-’.
1 <= k <= 104

题解:参考

class Solution:def licenseKeyFormatting(self, s: str, k: int) -> str:str_list = s.split('-')temp = ''.join(str_list)temp = temp[::-1]res = []for i in range(0, len(temp), k):if len(temp) -  i > k:res.append(temp[i:i+k])else:res.append(temp[i::])end_str = '-'.join(res)return end_str[::-1].upper()

来源:力扣(LeetCode)
链接:https://leetcode.cn/problems/license-key-formatting
著作权归领扣网络所有。商业转载请联系官方授权,非商业转载请注明出处。

http://www.lryc.cn/news/65893.html

相关文章:

  • STM32F4_十进制和BCD码的转换
  • random — 伪随机数生成器(史上总结最全)
  • 基于VBA实现成绩排序的最佳方法-解放老师的双手
  • OCAF如何实现引用关系和拓扑关系
  • 自动创建设备节点
  • JavaWeb ( 六 ) JSP
  • 2023世界超高清视频产业发展大会博冠8K明星展品介绍
  • Map接口以及Collections工具类
  • SOA协议DDS和Some/IP对比
  • Sass使用
  • 超大excel文件读,避免内存溢出
  • 第0章 学习之前的准备
  • 数组排序sort()方法
  • 【.NET AI Books 前言】Azure OpenAI Service 入门
  • 散列查找实验(开散列) 题目编号:583
  • Java版spring cloud 企业工程项目管理系统平台源码(三控:进度组织、质量安全、预算资金成本、二平台:招采、设计管理)
  • Go type关键字定义新类型和类型别名的区别
  • Neural Network学习笔记2
  • 用@Value注解为bean的属性赋值
  • 拨云见日:深入理解 HTML 解析器与有限状态机
  • Java线程池及其实现原理
  • 进程替换函数组介绍exec*
  • 欧科云链OKLink:2023年4月安全事件盘点
  • KubeVirt备份与还原方案【翻译】
  • 使用PyQt5设计一款简单的计算器
  • Htop使用说明
  • PostgreSQL Linux安装
  • 亚商投资顾问 早餐FM/0509车辆电动化
  • AI绘画天花板——Midjourney注册使用保姆级教程(5月5日验证有效)
  • 学习笔记(2)项目结构描述 - manifest.json和pages.json