利用Python/R語(yǔ)言分別解決金字塔數(shù)求和問題
前言
此專欄為python與R語(yǔ)言對(duì)比學(xué)習(xí)的文章;以通俗易懂的小實(shí)驗(yàn),帶領(lǐng)大家深入淺出的理解兩種語(yǔ)言的基本語(yǔ)法,并用以實(shí)際場(chǎng)景!感謝大家的關(guān)注,希望對(duì)大家有所幫助。
“博觀而約取,厚積而薄發(fā)!”謹(jǐn)以此言,望諸君共勉
本文將前兩個(gè)小實(shí)驗(yàn)整理拼湊再了一起 ;分別是“前N階乘求和、金字塔數(shù)求和”。具體的項(xiàng)目介紹見下文。
1、前N階乘求和
階乘是基斯頓·卡曼(Christian Kramp,1760~1826)于 1808 年發(fā)明的運(yùn)算符號(hào),是數(shù)學(xué)術(shù)語(yǔ)。
n!=1∗2∗3∗...∗(n−1)∗n
或者可以使用遞歸方式定義:

對(duì)其前N項(xiàng)階乘求和即是sum(1!+2!+3!+...+n!),有了以上的理論基礎(chǔ),我們一起看看圖解,加強(qiáng)一下理解 !
1.1 圖解問題

如圖,如果要輸出每一個(gè)值 ,可以嵌入循環(huán)的思想,每一次將前一個(gè)值進(jìn)行乘法運(yùn)算即可!
1.2 算法流程

在此可以看到 ,我們需要加以人工控制需要算前多少項(xiàng)。在循環(huán)體內(nèi),這是對(duì)階乘數(shù)的累加和賦值。
1.3 代碼實(shí)現(xiàn)
1.3.1 python代碼實(shí)現(xiàn)
n = int(input("n = "))
s = 0
t = 1
for i in range(1,n+1):
t*=i
s+=t
print ("前{}階乘的和是:{}" .format(n,s))

1.3.2 R語(yǔ)言代碼實(shí)現(xiàn)
factorial <- function(n){
n <<- as.integer(readline("請(qǐng)輸入需要階乘個(gè)數(shù)(從 1 開始):"))
fac = 1
ans = 0
for (i in 1:n) {
fac = fac * i
ans = ans + fac
}
return(ans)
}
test_3 <- function(){
print("前n階乘之和為:")
factorial(n)
}
test_3()
1.4實(shí)驗(yàn)小結(jié)
這個(gè)實(shí)驗(yàn)核心的點(diǎn)是循環(huán)的使用;
至于R代碼部分均使用函數(shù)的形式進(jìn)行包裝方便理解;函數(shù)內(nèi)部采用互動(dòng)的方式,便于拓展使用。有需要了解的留言或私信。
2、金字塔數(shù)求和運(yùn)算
此處的金字塔是真金字塔;就按簡(jiǎn)單的金字塔形狀的數(shù)字:

求s=a+aa+aa+aaa+aa...a的值,其中 a 是一個(gè)數(shù)字。例如:
2+22+222+2222+22222
(此時(shí)共 有 5 個(gè)數(shù)相加),幾個(gè)數(shù)相加由鍵盤控制。
2.1 圖解問題

通過對(duì)每一層金字塔數(shù)的拆解,即可得到如下的通項(xiàng)公式:

這樣問題不久又解決了嗎?與上面的前n項(xiàng)階乘求和一樣,使用循環(huán)求出每一層數(shù),然后求和。
2.2 算法流程

與上面實(shí)驗(yàn)基本沒有差異;主要是循環(huán)體的算法不同而已。此處不做講解了。
2.3 代碼實(shí)現(xiàn)
2.3.1 python代碼
a = int(input("請(qǐng)輸入需要a的值:"))
n = int(input("請(qǐng)輸入需要n的值:"))
Fn = 0
pyr = []
for i in range(n):
Fn = Fn + a
a = a*10
pyr.append(Fn)
print(Fn)
print("前{}個(gè)數(shù)的和為:{}".format(n, sum(pyr)))

2.3.2 R語(yǔ)言代碼實(shí)現(xiàn)
sum_pyr <- function(){
a <- as.integer(readline("請(qǐng)輸入a的值:"))
n <- as.integer(readline("請(qǐng)輸入n的值:"))
Fn <- 0
pyr <- c()
for (i in 1:n) {
Fn <- Fn + a
a <- a * 10
pyr[i] <- Fn
print(Fn)
}
ans <<- sum(pyr)
}
test_4 <- function(){
print("金字塔為:")
sum_pyr()
print("求和結(jié)果為:")
ans
}
test_4()

2.4 實(shí)驗(yàn)小結(jié)
這個(gè)實(shí)驗(yàn)核心的點(diǎn)是循環(huán)的使用;
至于R代碼部分均使用函數(shù)的形式進(jìn)行包裝方便理解;函數(shù)內(nèi)部采用互動(dòng)的方式,便于拓展使用。有需要了解的留言或私信。
總結(jié)
本文中Python與R語(yǔ)言語(yǔ)法小結(jié)
獲取鍵盤輸入值——input()函數(shù) VS readline()函數(shù)
本文主要對(duì)for循環(huán)玩法進(jìn)行了加深一步的介紹 。以及 R語(yǔ)言的函數(shù)體也是今后常用的結(jié)構(gòu)體!
以上就是利用Python/R語(yǔ)言分別解決金字塔數(shù)求和問題的詳細(xì)內(nèi)容,更多關(guān)于Python/R金字塔數(shù)求和的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!
相關(guān)文章
python嵌套函數(shù)使用外部函數(shù)變量的方法(Python2和Python3)
這篇文章主要介紹了python嵌套函數(shù)使用外部函數(shù)變量的方法,需要的朋友可以參考下2016-01-01
Python基于Webhook實(shí)現(xiàn)github自動(dòng)化部署
這篇文章主要介紹了Python基于Webhook實(shí)現(xiàn)github自動(dòng)化部署,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-11-11
python安裝后無(wú)法打開IDLE?Subprocess?Connection?Error的解決方法
有朋友在安裝了Python之后發(fā)現(xiàn)不能正常使用,就說明安裝過程出了問題,下面這篇文章主要給大家介紹了關(guān)于python安裝后無(wú)法打開IDLE?Subprocess?Connection?Error的解決方法,需要的朋友可以參考下2023-01-01
用Python實(shí)現(xiàn)通過哈希算法檢測(cè)圖片重復(fù)的教程
這篇文章主要介紹了用Python實(shí)現(xiàn)通過哈希算法檢測(cè)圖片重復(fù)的教程,這個(gè)方法被Iconfinder用作防盜版技術(shù),需要的朋友可以參考下2015-04-04
?分享4款Python 自動(dòng)數(shù)據(jù)分析神器
這篇文章主要給大家分享的是4款Python 自動(dòng)數(shù)據(jù)分析神器,我給大家分享 4 款常用的EDA工具,它們可以自動(dòng)產(chǎn)出統(tǒng)計(jì)數(shù)據(jù)和圖表,為我們節(jié)省大量時(shí)間,需要的朋友可以參考一下2022-03-03
Python庫(kù)skimage繪制二值圖像代碼實(shí)例
這篇文章主要介紹了Python庫(kù)skimage繪制二值圖像代碼實(shí)例,文中通過示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下2020-04-04
Python實(shí)現(xiàn)列表轉(zhuǎn)換成字典數(shù)據(jù)結(jié)構(gòu)的方法
這篇文章主要介紹了Python實(shí)現(xiàn)列表轉(zhuǎn)換成字典數(shù)據(jù)結(jié)構(gòu)的方法,結(jié)合實(shí)例形式分析了Python數(shù)值類型轉(zhuǎn)換的相關(guān)技巧,需要的朋友可以參考下2016-03-03
pycharm無(wú)法安裝第三方庫(kù)的問題及解決方法以scrapy為例(圖解)
這篇文章主要介紹了pycharm無(wú)法安裝第三方庫(kù)的解決辦法以scrapy為例,本文通過圖文并茂的形式給大家介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作具有一定的參考借鑒價(jià)值,需要的朋友可以參考下2020-05-05
Python查找最長(zhǎng)不包含重復(fù)字符的子字符串算法示例
這篇文章主要介紹了Python查找最長(zhǎng)不包含重復(fù)字符的子字符串算法,涉及Python字符串遍歷、統(tǒng)計(jì)相關(guān)操作技巧,需要的朋友可以參考下2019-02-02

