python统计并输出字符串中小写元音字母的个数?
Posted
tags:
篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了python统计并输出字符串中小写元音字母的个数?相关的知识,希望对你有一定的参考价值。
本人是python初学者,麻烦回答时候用比较简单的方法!!!
输入格式:
在一行中输入字符串
输出格式:
在一行中输出字符串中小写元音字母的个数
输入样例:
在这里给出一组输入。例如:
HelloI
输出样例:
在这里给出相应的输出。例如:
2
您好,下面为代码,如有问题,请追问:
import sys
vowel = ['a', 'e', 'i','o', 'u']
str = sys.argv[1]
sum = 0
for i in str:
if i in vowel:
sum+=1
print(sum)
使用方法:
将上面代码放入文件,例如test.py文件中
如果是linux或mac下给test.py加上可执行权限 //chmod +x test.py
执行格式: python test.py 字符串:
vowel是列表名吗?还有第三行也不太懂啥意思。
追答#导入sys库
import sys
#定义元音字母列表,该列表的初始值是5个元音字母,vowel就是随便一个名字,它是元音的意思,这个列表名可以随便取,但因为里面存的是元音字母嘛,就用了元音的英文单词命名
vowel = ['a', 'e', 'i','o', 'u']
#sys.argv[1]的作用是获取脚本执行时传递给脚本的第1个参数,例如执行脚本时我写的是python test.py name age,这里面name和age是传递给脚本test.py的参数,我们可以在test.py脚本的代码里引用这里的name和age,而引用的一种方法就是使用sys.argv,就上面所说的sys.argv[1]指的就是name,sys.argv[2]指的就是age.而上面给你写的代码执行时写的不是python test.py helloaeiou嘛,这里sys.argv[1]指的就是helloaeiou,也就是str=sys.argv[1]执行后,str的值就变成了“helloaeiou”,也就是说在给你的代码中,下面这行就表示 str="helloaeiou"
str = sys.argv[1]
#sum初始值为0,作用是下面遍历str中每个字母的时候,如果检测到的字母是元音字母就给sum变量加1,这样str中有多少个元音字母通过打印sum的值就看出来了
sum = 0
#遍历str中的每个字母,每次遍历的时候将值赋给变量i
for i in str:
#检查如果变量i的值在元音列表vowel中,则给sum的值加1,当然如果变量i的值不在vowel中,则不会执行下面的sum+=1,也就不会给改变sum的值
if i in vowel:
sum+=1
#最后把变量sum的值打印出来,这个值就是字符串中元音字符的个数
print(sum)
行,谢谢谢谢!
又说列表超过范围了
追答你把代码发上来,看不清图片
你执行命令咋写的?还有代码里sys.argv后面索引写的几?
追问import sys
vowel = ['a', 'e', 'i','o', 'u']
str = sys.argv[1]
sum = 0
for i in str:
if i in vowel:
sum+=1
print(sum)
我直接复制粘贴上去的,然后运行错误是
Traceback (most recent call last):
File "C:/Users/22786/Documents/python/python test.py", line 7, in
str = sys.argv[1]
IndexError: list index out of range
你是怎么运行的呢?
这个代码要在命令行运行,格式为:
python py文件名 字符串
不能直接粘到解释器中,如果想直接粘到解释器中用,直接把str=sys.argv[1]改为str="字符串"
本回答被提问者和网友采纳Python|Leetcode《1220》|统计元音字母序列的数目
专栏《LeetCode|一刷到底》
打卡每天leetcode精选每日一题(尽量不断更!)
点击关注不迷路!!!
一、题目描述
- 题目:统计元音字母序列的数目
- 难度:困难
- 地址:《统计元音字母序列的数目》
- 描述:给你一个整数 n,请你帮忙统计一下我们可以按下述规则形成多少个长度为 n 的字符串:
字符串中的每个字符都应当是小写元音字母('a', 'e', 'i', 'o', 'u'
)
每个元音'a'
后面都只能跟着'e'
每个元音'e'
后面只能跟着'a'
或者是'i'
每个元音'i'
后面 不能 再跟着另一个'i'
每个元音'o'
后面只能跟着'i'
或者是'u'
每个元音'u'
后面只能跟着'a'
由于答案可能会很大,所以请你返回 模 10^9 + 7 之后的结果。
- 示例1
输入:n = 1
输出:5
解释:所有可能的字符串分别是:"a", "e", "i" , "o"
和"u"
。
- 示例2
输入:n = 2
输出:10
解释:所有可能的字符串分别是:"ae", "ea", "ei", "ia", "ie", "io", "iu", "oi", "ou"
和"ua"
。
- 示例3
输入:n = 5
输出:68
提示:
- 1 <= n <= 2 * 1 0 4 10^4 104
二、题目解析
此题虽为难题,但是本质上可以看作是动态规划问题的一般形态。
初始形态为字符串长度为1的时候的形态(n=1
),后续随着n的增大,我们不断的替换每一层的字符中有几个a、e、i、o、u
即可,例如第二层的字符中,在第一层字符e、i、u
的后面会出现字符a
。图解如下:
不同颜色的连线代表第二层中的各个字符会由上一层中的哪些字符得到,上一层中有几个这样的字符数量就为几,后面依次类推即可。
三、解题代码
解法
class Solution:
def countVowelPermutation(self, n: int) -> int:
a, e, i, o, u = 1, 1, 1, 1, 1
for _ in range(n - 1):
a, e, i, o, u = e + u + i, a + i, o + e, i, i + o
return (a + e + i + o + u) % (10**9 + 7)
以上是关于python统计并输出字符串中小写元音字母的个数?的主要内容,如果未能解决你的问题,请参考以下文章