中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

怎么用Python寫算法題

發布時間:2021-10-28 18:35:11 來源:億速云 閱讀:211 作者:柒染 欄目:編程語言

這篇文章給大家介紹怎么用Python寫算法題,內容非常詳細,感興趣的小伙伴們可以參考借鑒,希望對大家能有所幫助。

題目

題目描述

給你n根火柴棍,你可以拼出多少個形如“A+B=C”的等式?等式中的A、B、C是用火柴棍拼出的整數(若該數非零,則最高位不能是00)。用火柴棍拼數字0-90?9的拼法如圖所示:
怎么用Python寫算法題

注意:

  1. 加號與等號各自需要兩根火柴棍

  2. 如果A≠B,則A+B=C與B+A=C視為不同的等式(A,B,C>=0)

  3. n根火柴棍必須全部用上

輸入格式

一個整數n(n<=24)。

輸出格式

一個整數,能拼成的不同等式的數目。

輸入輸出樣例

樣例1:

輸入

14

輸出

2

樣例2

輸入

18

輸出

9

解法

方法1:打表法

因為n的最大值只有24,那么可以直接提前把答案窮舉出來。

# 0-9需要多少根火柴棒
num =[6, 2, 5, 5, 4, 5, 6, 3, 7, 6]

# 輸入一個數,計算需要多少火柴棒
def count(x):
    if x == 0:
        return 6
    c = 0
    while x > 0:
        digit = x % 10
        c += num[digit]
        x = x // 10
    return c

result = [0] * 24

for n in range(10, 25): #10根火柴以下都是0,很明顯
    print("caculate ", n)
    for i in range(0, 10000): #假設單個數字最大值為10000
        for j in range(0, 10000):
            if count(i) + count(j) + count(i+j) == n - 4:
                result[n-1] += 1
print(result)

上述代碼在我的電腦上跑半天也出不來,最大值改成2000就可以。同樣的代碼,用Java很快就出結果了,足以說明Python并不適合這一類的題目。

public class Test {
    public static void main(String[] args) {
        int[] result = new int[24];
        for(int i = 10; i <= 24; i++) {
            for(int j = 0; j < 10000; j++) {
                for(int k = 0; k < 10000; k++) {
                    if(count(j) + count(k) + count(j+k) == i - 4) {
                        result[i] += 1;
                    }
                }
            }
        }
        for(int i = 0; i < 24; i++) {
            System.out.println(result[i]);
        }

    }
    public static int[] num = {6,2,5,5,4,5,6,3,7,6};
    public static int count(int x) {
        if(x == 0) {
            return 6;
        }
        int c = 0;
        while (x > 0) {
            int digit = x % 10;
            c += num[digit];
            x = x / 10;
        }
        return c;
    }
}

最后結果是{0,0,0,0,0,0,0,0,0,0,0,0,0,1,2,8,9,6,9,29,39,38,65,88,128}。

但是雖然是窮舉,但是上面代碼有個問題,每次都要重復調用count,提前把count存起來就行了,雖然用Python還是很慢,但是能夠在可接受時間內出結果。

# 0-9需要多少根火柴棒
num =[6, 2, 5, 5, 4, 5, 6, 3, 7, 6]

# 輸入一個數,計算需要多少火柴棒
def count(x):
    if x == 0:
        return 6
    c = 0
    while x > 0:
        digit = x % 10
        c += num[digit]
        x = x // 10
    return c

COUNT = [0] * 20000
for i in range(0, 20000):
    COUNT[i] = count(i)

result = [0] * 24

for n in range(10, 25):
    print("caculate ", n)
    for i in range(0, 10000):
        for j in range(0, 10000):
            if COUNT[i] + COUNT[j] + COUNT[i+j] == n - 4:
                result[n-1] += 1
print(result)

方法2:優化上述方法

沒有什么更好的方法,我們可以盡量減少循環次數,另外,如果能知道單個數的最大值,那就更好辦了。

要想用最少的火柴棒拼出最大的數,那優先得拼出最大的數字個數,因為999肯定要比1111小,因為一個數字至少2個火柴,所以對于偶數個火柴,肯定是用拼成11111這樣的最大,例如10根火柴,能拼出的最大數是11111,20個火柴,能拼出的最大數是1111111111。

假設最大值超過10000,那至少需要10根,能拼出11111,剩下10根分成8+2根,兩個湊起來不可能超過10000,所以最大值不超過10000。

假設最大值可能位于[9000,10000),至少需要12根,能拼出9111,剩下8根不可能加起來等于這個數。

假設最大值可能位于[8000,9000),至少需要13根,更不可能。

假設最大值可能位于[7000,8000),至少需要9根,也就是7111,剩下11根,,如果分成9+2,2根只能是1,所以9根必須拼成7110,不夠數。

假設最大值可能位于[6000,7000),至少需要12根,剩下8根也不行。

假設最大值可能位于[5000,6000),至少需要11根,剩下9根能拼出的最大4位數是7xxx或者1xxx,加起來不可能是5000。對于[2000,5000)也一樣。

假設最大值可能位于[1900,2000],那么最少需要12根,1911,剩下的沒法相加為1911。

依次分析,我們發現最大數不可能大于1111。通過程序結果來看,最大值為712。

改進之后,不用打表也能AC。

# 0-9需要多少根火柴棒
num =[6, 2, 5, 5, 4, 5, 6, 3, 7, 6]

# 輸入一個數,計算需要多少火柴棒
def count(x):
    if x == 0:
        return 6
    c = 0
    while x > 0:
        digit = x % 10
        c += num[digit]
        x = x // 10
    return c

COUNT = [0] * 713
for i in range(0, 713):
    COUNT[i] = count(i)

result = 0

n = int(input())

for i in range(0, 712):
    for j in range(0, 712):
        if i + j > 712:
            continue
        if COUNT[i] + COUNT[j] + COUNT[i+j] == n - 4:
            result += 1

print(result)

關于怎么用Python寫算法題就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

太保市| 界首市| 阿巴嘎旗| 任丘市| 丰城市| 临沧市| 太湖县| 池州市| 德庆县| 鄂州市| 南平市| 宁海县| 贵南县| 安徽省| 德阳市| 前郭尔| 靖安县| 岳池县| 嘉峪关市| 合肥市| 罗山县| 榆林市| 彭阳县| 宽甸| 凤庆县| 思茅市| 乐山市| 沾益县| 彭山县| 高密市| 衡阳市| 阳信县| 朝阳市| 绵竹市| 建德市| 汉阴县| 定陶县| 米林县| 北海市| 松原市| 雷波县|