Heim > Backend-Entwicklung > Python-Tutorial > Lassen Sie uns über Ideen zur Python-Programmierung sprechen

Lassen Sie uns über Ideen zur Python-Programmierung sprechen

WBOY
Freigeben: 2022-06-27 13:55:05
nach vorne
2841 Leute haben es durchsucht

Dieser Artikel vermittelt Ihnen relevantes Wissen über Python, das hauptsächlich Probleme im Zusammenhang mit Programmierideen organisiert. Python ist eine objektorientierte oop-Skriptsprache (Object Oriented Programming). Der Kern von Programmierideen ist das Verständnis. Werfen wir einen Blick auf die Funktionalität Logik unten. Ich hoffe, dass es für alle hilfreich sein wird.

Lassen Sie uns über Ideen zur Python-Programmierung sprechen

Empfohlenes Lernen: Python-Video-Tutorial

Python ist eine objektorientierte Skriptsprache oop (Object Oriented Programming).

Objektorientiert ist eine Methode, die das Konzept von Objekten (Entitäten) nutzt, um Modelle zu erstellen und die objektive Welt zu simulieren, um Software zu analysieren, zu entwerfen und zu implementieren.

In der objektorientierten Programmierung enthalten Objekte zwei Bedeutungen, eine davon sind Daten und die andere ist Aktion. Der objektorientierte Ansatz verbindet Daten und Methoden zu einem Ganzen und modelliert es anschließend systemisch.

Der Kern des Python-Programmierdenkens ist das Verstehen der Funktionslogik Wenn Sie die Logik zur Lösung eines Problems nicht verstehen, sieht Ihr Code sehr chaotisch und schwer lesbar aus. Sobald die Logik klar ist, Führen Sie eine systematische Programmierung von Funktionen nach Modulen durch, dann wird Ihr Code-Design auf jeden Fall schön sein! ! !

1 Grundlegendes Programmiermuster

Jede Programmierung umfasst IPO, die Folgendes darstellen:

  • I: Eingabe, die Eingabe des Programms

  • P: Prozess, der wichtigste logische Prozess des Programms

  • O: Ausgabe, die Ausgabe des Programms

Wenn Sie also eine bestimmte Funktion über einen Computer implementieren möchten, dann enthält das grundlegende Programmiermuster drei Teile wie folgt:

  • Bestimmen Sie den IPO: Klären Sie die Eingabe und Ausgabe der zu implementierenden Funktionen sowie den Hauptimplementierungslogikprozess.

  • Programme schreiben: Entwerfen und zeigen Sie den logischen Prozess der Berechnung und Lösung mithilfe von Programmiersprachen an : Befolgen Sie die Logik des geschriebenen Programms. Debuggen Sie den Prozess, um sicherzustellen, dass das Programm gemäß der richtigen Logik ordnungsgemäß ausgeführt wird.

  • 2 Effektive Methode zur Lösung komplexer Probleme: Top-Down (Design)

2.1 Top-Down – Teilen und Herrschen

Wenn die Logik zur Implementierung der Funktion relativ komplex ist, muss sie implementiert werden Modularer Entwurf

zerlegt komplexe Probleme in mehrere einfache Probleme, und die einfachen Probleme können weiterhin in einfachere Probleme zerlegt werden, bis die Funktionslogik durch Modulprogrammierung realisiert werden kann, die auch Programmierung ist Top-DownFunktionen. Die Zusammenfassung lautet wie folgt: Drücken Sie ein allgemeines Problem in eine Form aus, die aus mehreren kleinen Problemen besteht.

Verwenden Sie dieselbe Methode, um kleine Probleme weiter zu zerlegen.
  • Bis die kleinen Probleme einfach und klar von Computern gelöst werden können.
  • 2.2 Beispiel 1: Sportwettkampfanalyse

2.2.1 Gesamtprogrammrahmen

printlninfo()                 Schritt 1: Einleitende Informationen zum Programm ausdrucken                                                                                                                    Schritt 2: Ermitteln Sie die Programmlaufparameter: proA, proB, n simNGames( ) Schritt 3: Verwenden Sie die Fähigkeitswerte der Spieler A und B, um n Spiele zu simulieren

printSummary() Schritt 4: Geben Sie die Anzahl und Wahrscheinlichkeit der Spieler A und B aus, die das Spiel gewinnen




2.3 Beispiel 2: Die Top-Down-Methode der Fibonacci-Sequenz

verwendet tatsächlich Rekursion, um das Unterproblem zu lösen Die endgültige Lösung muss nur die rekursive Formel aufrufen. Probleme werden Schritt für Schritt rekursiv auf die unteren Ebenen gelöst.

Programmierung:

# 导入python资源包
from random import random
 
# 用户体验模块 
def printIntro():
    print("这个程序模拟两个选手A和B的某种竞技比赛")
    print("程序运行需要A和B的能力值(以0到1之间的小数表示)")
 
# 获得A和B的能力值与场次模块 
def getIntputs():
    a = eval(input("请输入A的能力值(0-1):"))
    b = eval(input("请输入B的能力值(0-1):"))
    n = eval(input("模拟比赛的场次:"))
    return a, b, n
 
# 模拟n局比赛模块 
def simNGames(n, probA, probB):
    winsA, winsB = 0, 0
    for i in range(n):
        scoreA, scoreB = simOneGame(probA, probB)
        if scoreA > scoreB:
            winsA += 1
        else:
            winsB += 1
    return winsA, winsB
 
# 判断比赛结束条件 
def gameOver(a, b):
    return a == 15 or b == 15
 
# 模拟n次单局比赛=模拟n局比赛 
def simOneGame(probA, probB):
    scoreA, scoreB = 0, 0
    serving = "A"
    while not gameOver(scoreA, scoreB):
        if serving == "A":
            if random() < probA:
                scoreA += 1
            else:
                serving = "B"
        else:
            if random() < probB:
                scoreB += 1
            else:
                serving = "A"
    return scoreA, scoreB
 
# 打印结果模块 
def printSummary(winsA, winsB):
    n = winsA + winsB
    print("竞技分析开始,共模拟{}场比赛".format(n))
    print("选手A获胜{}场比赛,占比{:0.1%}".format(winsA, winsA / n))
    print("选手B获胜{}场比赛,占比{:0.1%}".format(winsB, winsB / n))
 
 
def main():
    printIntro()    
    probA, probB, n = getIntputs()                # 获得用户A、B能力值与比赛场次N
    winsA, winsB = simNGames(n, probA, probB)     # 获得A与B的场次
    printSummary(winsA, winsB)                    # 返回A与B的结果
 
 
main()
Nach dem Login kopieren

Laufende Ergebnisse:

cache = {}

def fib(number):
    if number in cache:
        return cache[number]
    if number == 0 or number == 1:
        return 1
    else:
        cache[number] = fib(number - 1) + fib(number - 2)
    return cache[number]

if __name__ == &#39;__main__&#39;:
    print(fib(35))
Nach dem Login kopieren

Top-Down-Design-Denken verstehen: Teile und herrsche

3 Effektive Testmethoden für den schrittweisen Aufbau komplexer Systeme : von unten nach oben Nach oben (Ausführung)

3.1 Bottom-up – modulare Integration

自底向上(执行)就是一种逐步组建复杂系统的有效测试方法。首先将需要解决的问题分为各个三元进行测试,接着按照自顶向下相反的路径进行操作,然后对各个单元进行逐步组装,直至系统各部分以组装的思路都经过测试和验证。

理解自底向上的执行思维:模块化集成

自底向上分析思想:

  • 任何时候栈中符号串和剩余符号串组成一个句型,当句柄出现在栈顶符号串中时,就用该句柄进行归约,这样一直归约到输入串只剩结束符、栈中符号只剩下开始符号,此时认为输入符号串是文法的句子,否则报错。

自底向上是⼀种求解动态规划问题的方法,它不使用递归式,而是直接使用循环来计算所有可能的结果,往上层逐渐累加子问题的解。在求解子问题的最优解的同时,也相当于是在求解整个问题的最优解。其中最难的部分是找到求解最终问题的递归关系式,或者说状态转移方程。

3.2 举例:0-1背包问题

3.2.1 问题描述

你现在想买⼀大堆算法书,有一个容量为 V 的背包,这个商店⼀共有 n 个商品。问题在于,你最多只能拿 W kg 的东西,其中 wi vi 分别表示第 i 个商品的重量和价值。最终的目标就是在能拿的下的情况下,获得最大价值,求解哪些物品可以放进背包。

对于每⼀个商品你有两个选择:拿或者不拿。

3.2.2 自底向上分析

⾸先要做的就是要找到“子问题”是什么。通过分析发现:每次背包新装进⼀个物品就可以把剩余的承重能力作为⼀个新的背包来求解,⼀直递推到承重为0的背包问题。

m[i,w] 表示偷到商品的总价值,其中 i 表示⼀共多少个商品,w 表示总重量,所以求解 m[i,w]就是子问题,那么看到某⼀个商品i的时候,如何决定是不是要装进背包,需要考虑以下:

  • 该物品的重量大于背包的总重量,不考虑,换下⼀个商品;
  • 该商品的重量小于背包的总重量,那么尝试把它装进去,如果装不下就把其他东西换出来,看看装进去后的总价值是不是更高了,否则还是按照之前的装法;
  • 极端情况,所有的物品都装不下或者背包的承重能力为0,那么总价值都是0;

由以上的分析,可以得出m[i,w]的状态转移方程为:

m[i,w] = max{m[i-1,w], m[i-1,w-wi]+vi}

3.2.3 程序设计

# 循环的⽅式,自底向上求解
cache = {}
items = range(1,9)
weights = [10,1,5,9,10,7,3,12,5]
values = [10,20,30,15,40,6,9,12,18]
# 最⼤承重能⼒
W = 4

def knapsack():
    for w in range(W+1):
        cache[get_key(0,w)] = 0
    for i in items:
        cache[get_key(i,0)] = 0
        for w in range(W+1):
            if w >= weights[i]:
                if cache[get_key(i-1,w-weights[i])] + values[i] > cache[get_key(i-1,w)]:
                    cache[get_key(i,w)] = values[i] + cache[get_key(i-1,w-weights[i])]
                else:
                    cache[get_key(i,w)] = cache[get_key(i-1,w)]
            else:
                cache[get_key(i,w)] = cache[get_key(i-1,w)]
    return cache[get_key(8,W)]

def get_key(i,w):
    return str(i)+','+str(w)

if __name__ == '__main__':
    # 背包把所有东西都能装进去做假设开始
    print(knapsack())
Nach dem Login kopieren
29
>>>
Nach dem Login kopieren

推荐学习:python

Das obige ist der detaillierte Inhalt vonLassen Sie uns über Ideen zur Python-Programmierung sprechen. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!

Verwandte Etiketten:
Quelle:csdn.net
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage