Python Day-String 使用循环、递归、任务的函数逻辑

python day-string 使用循环、递归、任务的函数逻辑

1) 在字符串之间添加空格

txt = "todayisfriday"#today is fridayfirst = truefor letter in txt:    if letter>='a' and letter<='z':        if first==true:            first = false        else:            print(' ',end='')    print(letter,end='')

登录后复制

输出:
今天是星期五

2) 删除字符串之间的空格

txt = "    today is friday"#today is fridayfor letter in txt:    if letter==' ':        pass    else:        print(letter,end='')

登录后复制

输出:
今天是星期五

3) ltrim- 删除字符串左侧的空格。

#ltrimtxt = "    today is friday"#today is fridayalphabet = falsefor letter in txt:    if letter==' ' and alphabet == false:        pass    else:        alphabet = true        print(letter,end='')

登录后复制

4) rtrim- 删除字符串右侧的空格。

txt = "today is friday   "#today is fridayalphabet = falsei = len(txt)-1while i>=0:    letter = txt[i]    if letter==' ' and alphabet == false:        pass    else:        alphabet = true        end = i        j = 0        while j<=end:            print(txt[j],end='')            j+=1        break    i-=1

登录后复制

输出:

今天是星期五

立即学习“Python免费学习笔记(深入)”;

5) 从给定字符串中删除不需要的空格

txt = "today          is             friday"#today is fridayi = 0 while i<len(txt):    if txt[i] != ' ':        print(txt[i],end='')    else:        if txt[i-1]!=' ':            print(txt[i],end='')    i+=1

登录后复制

输出:

今天是星期五

立即学习“Python免费学习笔记(深入)”;

递归:
函数调用自身。

循环–>迭代方法。
递归–>递归方法。

示例:1

def display(no):    print(no, end=' ')    no+=1    if no<=5:        display(no)display(1)

登录后复制

输出:

1 2 3 4 5

登录后复制

调用阶乘的递归函数:

5!=5x4x3x2x1(或)5×4!

4!=4x3x2x1(或)4×3!

3!=3x2x1(或)3×2!

2!=2×1(或)2×1!

1!=1

示例:2

def find_fact(no):    if no==1:        return 1    return no * find_fact(no-1)result = find_fact(5)print(result)

登录后复制

输出:
120

说明:
1) find_fact(5)
返回 5 * find_fact(4) #no-1 = 5-1 –>4

2) find_fact(4)
返回 4 * find_fact(3) #no-1 = 4-1 –>3

3) find_fact(3)
返回 3 * find_fact(2) #no-1 = 3-1 –>2

4) find_fact(2)
返回 2 * find_fact(1) #no-1 = 2-1 –>1

5) find_fact(1)
基本情况:返回 1

基本情况:递归中的基本情况是停止递归调用的条件。

任务:

strip() – 删除字符串开头和结尾的所有空白字符(空格、制表符、换行符)。

1) 删除给定字符串前后不需要的空格。

txt = "    today is friday   "start = 0end = len(txt) - 1while start = 0:    i = start    while i = 0 and txt[j] == ' ':        j -= 1    end = j    break  result = txt[start:end+1]print(result)

登录后复制

输出:

today is friday

登录后复制

2)使用递归函数反转数字:

def reverse_a_no(no,reverse = 0):    if no==0:        return reverse        rem = no%10    reverse = (reverse*10) + rem    no=no//10     return reverse_a_no(no,reverse)no = int(input("enter no. ")) reversed_no = reverse_a_no(no) print(reversed_no)

登录后复制

输出:

enter no. 1551

登录后复制

3)是否找到质数:

def find_prime(no,div=2):    if div<no:         if no%div == 0:            return false        div+=1        return find_prime(no,div)    else:        return trueno=int(input("enter the number: "))if find_prime(no):    print("emirp number")else:    print("not emirp number")

登录后复制

输出:

1) enter the number: 11   emirp number2) enter the number: 15   not emirp number

登录后复制

4) 查找斐波那契数:

def find_fibonacci(first_num,sec_num,no):    if first_num > no:        return    print(first_num, end=" ")    find_fibonacci(sec_num,first_num+sec_num,no)      no = int(input("enter the number: ")) find_fibonacci(0,1,no)

登录后复制

输出:

enter the number: 100 1 1 2 3 5 8 

登录后复制

5。是否查找回文:

def palindrome(num,count=0):    if num == 0:        return count    return palindrome(num//10,count*10+num%10)num=int(input("enter the number:"))result=palindrome(num)if result==num:    print("palindrome")else:    print("not palindrome")

登录后复制

输出:

Enter the number:121Palindrome

登录后复制

已创建 hackerrank 帐户:https://www.hackerrank.com/dashboard

以上就是Python Day-String 使用循环、递归、任务的函数逻辑的详细内容,更多请关注【创想鸟】其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至253000106@qq.com举报,一经查实,本站将立刻删除。

发布者:PHP中文网,转转请注明出处:https://www.chuangxiangniao.com/p/2175250.html

(0)
上一篇 2025年2月25日 12:32:35
下一篇 2025年2月18日 00:59:38

AD推荐 黄金广告位招租... 更多推荐

相关推荐

发表回复

登录后才能评论