力扣(leetcode)13和14题(Python)

13.罗马数字转整数

题目链接:13.罗马数字转整数

罗马数字包含以下七种字符: I, V, X, L,C,D 和 M。

字符 数值
I 1
V 5
X 10
L 50
C 100
D 500
M 1000

例如, 罗马数字 2 写做 II ,即为两个并列的 1 。12 写做 XII ,即为 X + II 。 27 写做 XXVII, 即为 XX + V + II 。

通常情况下,罗马数字中小的数字在大的数字的右边。但也存在特例,例如 4 不写做 IIII,而是 IV。数字 1 在数字 5 的左边,所表示的数等于大数 5 减小数 1 得到的数值 4 。同样地,数字 9 表示为 IX。这个特殊的规则只适用于以下六种情况:

I 可以放在 V (5) 和 X (10) 的左边,来表示 4 和 9。

X 可以放在 L (50) 和 C (100) 的左边,来表示 40 和 90。

C 可以放在 D (500) 和 M (1000) 的左边,来表示 400 和 900。

给定一个罗马数字,将其转换成整数。

示例 1:

输入: s = "III" 输出: 3
示例 2:

输入: s = "IV"

输出: 4
示例 3:

输入: s = "IX"

输出: 9
示例 4:

输入: s = "LVIII"

输出: 58

解释: L = 50, V= 5, III = 3.
示例 5:

输入: s = "MCMXCIV"

输出: 1994

解释: M = 1000, CM = 900, XC = 90, IV = 4.

提示:

1 <= s.length <= 15

s 仅含字符 ('I', 'V', 'X', 'L', 'C', 'D', 'M')

题目数据保证 s 是一个有效的罗马数字,且表示整数在范围 [1, 3999] 内

题目所给测试用例皆符合罗马数字书写规则,不会出现跨位等情况。

IL 和 IM 这样的例子并不符合题目要求,49 应该写作 XLIX,999 应该写作 CMXCIX 。

关于罗马数字的详尽书写规则,可以参考 罗马数字 - Mathematics 。

解答
sql 复制代码
class Solution:
    def romanToInt(self, s: str) -> int:
        dic = {
        'I':1,
        'V':5,
        'X':10,
        'L':50,
        'C':100,
        'D':500,
        'M':1000}
        num = 0
        later_num = 0
        for i in range(len(s)):
            if dic[s[i]]<=later_num:
                num += dic[s[i]]
            else:
                num = num + dic[s[i]] - 2*later_num
            later_num = dic[s[i]]
        return num

14.最长公共前缀

题目链接:14.最长公共前缀

编写一个函数来查找字符串数组中的最长公共前缀。

如果不存在公共前缀,返回空字符串 ""。

示例 1:

输入:strs = ["flower","flow","flight"]

输出:"fl"
示例 2:

输入:strs = ["dog","racecar","car"]

输出:""

解释:输入不存在公共前缀。

提示:

1 <= strs.length <= 200

0 <= strs[i].length <= 200

strs[i] 仅由小写英文字母组成

解答
sql 复制代码
class Solution:
    def longestCommonPrefix(self, strs: List[str]) -> str:
        if not strs:
            return ""
        
        length,count = len(strs[0]),len(strs)
        for i in range(length):
            c = strs[0][i]
            if any(i==len(strs[j]) or strs[j][i]!=c for j in range(1,count)):
                return strs[0][:i]
        return strs[0]

最后,我写了一篇MySQL教程,里面详细的介绍了MySQL的基本概念以及操作指令等内容,欢迎阅读!
MySQL数据库万字保姆级教程

相关推荐
阿里云大数据AI技术11 分钟前
阿里云PAI助力新一代Qwen3.5模型发布!
人工智能·算法
q12345678909823 分钟前
FNN sin predict
开发语言·python
小白菜又菜29 分钟前
Leetcode 221. Maximal Square
算法·leetcode·职场和发展
先做个垃圾出来………36 分钟前
Python字节串“b“前缀
开发语言·python
流云鹤1 小时前
牛客周赛Round 132(无F)
算法
Lee川1 小时前
深入解析:从内存模型到作用域陷阱——JavaScript变量的前世今生
javascript·算法
㓗冽1 小时前
回文数2(字符串)-基础题97th + 加法器(字符串)-基础题98th + 构造序列(字符串)-基础题99th
算法
dreams_dream1 小时前
什么是迭代器和生成器
python
悠闲蜗牛�1 小时前
深入浅出Spring Boot 3.x:新特性全解析与实战指南
开发语言·python