python 遞歸和二分法

来源:https://www.cnblogs.com/a2534786642/archive/2018/12/13/10116506.html
-Advertisement-
Play Games

一 內置函數 1. revserd 翻轉,返回的是迭代器 2.slice 切片 3.formate 4. type() 返回類型 ord() 輸入字元找字元編碼的位置 chr() 輸入位置找出對應的字元 ascii()判斷給出的信息是否是ascii 二. 遞歸 函數自己調用自己,遞歸的入口(參數) ...


一 內置函數

  1. revserd 翻轉,返回的是迭代器

# 將 s 倒置
s = '不是上海自來水來自海上'
# 方法一
print(s[::-1])
# 方法二
s1 = reversed(s)
i = ''
for el in s1:
  i +=el
  print(i)

  2.slice 切片

lis = ['nishi','woshi','shuia','benjim']
s = slice(1,3)
print(lis[s])

  3.formate

# 格式化輸出
s = "我叫{name},我想去{adress},我喜歡{hobby}.".format(name='zhangmeng',adress='上海',hobby='dance')
print(s)


# 字元串
print(format('test', '<20')) # 左對齊
print(format('test', '>20')) # 右對齊
print(format('test', '^20')) # 居中
# 數值
print(format(3, 'b')) # 二進位
print(format(97, 'c')) # 轉換成unicode字元
print(format(11, 'd')) # 十進位
print(format(11, 'o')) # 八進位
print(format(11, 'x')) # 十六進位(小寫字母)
print(format(11, 'X')) # 十六進位(大寫字母)
print(format(11, 'n')) # 和d一樣
print(format(11)) # 和d一樣
# 浮點數
print(format(123456789, 'e')) # 科學計數法. 預設保留6位小數
print(format(123456789, '0.2e')) # 科學計數法. 保留2位小數(小寫)
print(format(123456789, '0.2E')) # 科學計數法. 保留2位小數(大寫)
print(format(1.23456789, 'f')) # 小數點計數法. 保留6位小數
print(format(1.23456789, '0.2f')) # 小數點計數法. 保留2位小數
print(format(1.23456789, '0.10f')) # 小數點計數法. 保留10位小數
print(format(1.23456789e+10000, 'F')) # 小數點計數法.

  4. type() 返回類型    ord()  輸入字元找字元編碼的位置     chr()  輸入位置找出對應的字元    ascii()判斷給出的信息是否是ascii 

for i in range(65536):
    print(chr(i), end="")

二. 遞歸

  函數自己調用自己,遞歸的入口(參數)  和 出口(return)

語法:

def func():
    print('我是遞歸')
    func()

func() # 官方顯示最多到1000.但不會跑到1000,實際到998
# 樹形結構的遍歷

import os
def func(lujing, n):
    lis = os.listdir(lujing) # 打開文件夾,列出文件夾內的所有文件名
    for el in lis: # el 為文件的名字
    # 還原文件路徑
    path = os.path.join(lujing,el)
    if os.path.isdir(path):# 判斷路徑是否是文件夾
        print('*' * n,el) # 顯示文件夾的名字
        func(path, n+1) # 再來一次
    else:
        print('/t'*n,el) # 顯示文件

func('f:/a', 0)
import os
def func(lujing, n):
    lis = os.listdir(lujing ) # 打開文件夾,列出文件夾內的所有文件名
    for el in lis: # el為文件名
# 還原文件的路徑
    path = os.path.join(lujing, el)
    if os.path.isdir(path): # 判斷路徑是否是文件夾
        print('*'* n, el) # 顯示文件夾名稱
        func(path, n+1) # 再來一次
    else:
        with open(path,mode='wb') as f: # 打開文件,都寫入內容
            f.write(b'123456')
              print('/t'*n, el) # 顯示文件
func('F:/a',0)

三. 二分法

  掐頭結尾取中間,查找效率非常高,二分法查找的主要作用就是查找元素
# 二分法查找
lst = [1,4,6,7,9,21,23,45,67,87,65,43,89]
n = int(input('請輸入一個數:'))
lst = sorted(lst)
# print(lst)
left = 0
right = len(lst)-1
while left <= right:
    mid = (left + right)//2
    if n > lst[mid]:
        left = mid+1
    elif n < lst[mid]:
        right = mid -1
     else:
        print("存在")
        break
else:
print('不存在')
# 遞歸 切割列表

def func(n,lst):
    left = 0
    right = len(lst)-1
    if lst != []:
        mid = (left+right)//2
         if n>lst[mid]:
            func(n,lst[mid+1:])
        elif n < lst[mid]:
            func(n,lst[:mid])
        else:
            print("找到了")
            return
    else:
        print("沒找到")
        return

n = int(input('請輸入你要查找的數:'))
lst = [1,4,6,7,9,21,23,45,67,87,65,43,89]


func(n,lst)
# 遞歸2
def func(n,lst,left,right): # 遞歸找到什麼是可變的,什麼是不可變的
    if left <= right:
        mid = (left+right)//2
            if n > lst[mid]:
                left = mid+1
                return func(n,lst,left,right)
            elif n < lst[mid]:
                right = mid - 1
                return func(n, lst, left, right)
            else:
                print('找到了')
                return mid # 難點
    else:
        print('找不到')
        return -1

n = int(input('請輸入你要查找的數:'))
lst = [13,45,56,67,78,57,89,101]
ret = func(n,lst,0,len(lst)-1)
print(ret)
# 最快的查找方法

lst = [13,45,56,57,67,78,89,101]

# 找出最大的數
new_lst = []
for i in range(99):
    new_lst.append(0)

for i in lst:
    new_lst[i] = 1

i = int(input('請輸入你要找的數據:'))
if new_lst[i] == 0:
    print('不存在')
else:
    print('存在')

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • MyBatis開發原始Dao層請閱讀我的上一篇博客:MyBatis開發Dao層的兩種方式(原始Dao層開發) 接上一篇博客繼續介紹MyBatis開發Dao層的第二種方式:Mapper動態代理方式 Mapper介面開發方法只需要程式員編寫Mapper介面(相當於Dao介面),由Mybatis框架根據接 ...
  • 一:簡介:前身是阿裡巴巴的一個開源的項目,後來停止維護,由噹噹網繼續維護,它致力於rpc遠程的調度方案.是一個服務框架 二:執行原理圖: 節點角色說明: · Provider: 暴露服務的服務提供方。 · Consumer: 調用遠程服務的服務消費方。 · Registry: 服務註冊與發現的註冊中 ...
  • 本周我們介紹了以繼承方式實現的媒體資料庫,在課程代碼實現的基礎上,請實現一個表達MP3的媒體類型,能和CD、DVD一樣存放進這個Database。請提交這個MP3類的代碼。如果你認為為了能存放MP3,需要修改Item和Database,也請一併提交Item和Database的代碼。 本周我們介紹了以 ...
  • 1.昨日的補充 reversed 翻轉, 將一個序列翻轉,返回翻轉序列的迭代器 lst = ["河南話", "四川話", "東北", "山東", "上海"] n = reversed(lst) print(list(n)) lst = ["河南話", "四川話", "東北", "山東", "上海"] ...
  • 給定一個數組 nums,有一個大小為 k 的滑動視窗從數組的最左側移動到數組的最右側。你只可以看到在滑動視窗 k 內的數字。滑動視窗每次只向右移動一位。 返回滑動視窗最大值 其實這道題就是求給定數組中獲取全部K個連續元素中最大值的集合 首先我們可能會遇到三中情況 當原始數組為空的,那就直接返回一個空 ...
  • 一:環境準備: Windows、JDK1.8+、Maven、Git 二:RocketMQ準備: 1.http://rocketmq.apache.org/release_notes/release-notes-4.2.0/ 2.選擇‘Binary’進行下載 下完完畢之後解壓 三:配置 進行環境變數配 ...
  • 工廠模式 實現創建者和調用者的分離 簡單工廠,工廠方法,抽象工廠模式。 面向對象的設計原則:OCP(開閉原則):軟體的設計應該對擴展開放,對修改關閉 DIP(依賴倒轉原則):應該針對介面編程,不應該針對實現編程。 簡單工廠: 例: //頂級介面 public interface Car extend ...
  • 入門示例 異常處理:try/except 對於索引查找的操作,在索引越界搜索的時候會報錯。例如: 所報的錯誤是IndexError。如果將索引查找放在一個函數里: 那麼調用函數的時候,如果裡面的索引越界了,異常將彙報到函數調用者。 可以使用try/except來捕獲異常。作為入門示例,下麵是簡單版的 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...