網(wǎng)站首頁(yè) 編程語(yǔ)言 正文
前言
此專欄為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)目介紹見(jiàn)下文。
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 圖解問(wèn)題
如圖,如果要輸出每一個(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 開(kāi)始):")) 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ù)相加由鍵盤(pán)控制。
2.1 圖解問(wèn)題
通過(guò)對(duì)每一層金字塔數(shù)的拆解,即可得到如下的通項(xiàng)公式:
這樣問(wèn)題不久又解決了嗎?與上面的前n項(xiàng)階乘求和一樣,使用循環(huán)求出每一層數(shù),然后求和。
2.2 算法流程
與上面實(shí)驗(yàn)基本沒(méi)有差異;主要是循環(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é)
獲取鍵盤(pán)輸入值——input()函數(shù) VS readline()函數(shù)
本文主要對(duì)for循環(huán)玩法進(jìn)行了加深一步的介紹 。以及 R語(yǔ)言的函數(shù)體也是今后常用的結(jié)構(gòu)體!
原文鏈接:https://blog.csdn.net/weixin_42873544/article/details/123682208
相關(guān)推薦
- 2022-09-18 python實(shí)現(xiàn)修改xml文件內(nèi)容_python
- 2022-04-07 一篇文章帶你學(xué)習(xí)Python3的高級(jí)特性(2)_python
- 2022-10-27 C++移動(dòng)語(yǔ)義介紹與使用講解_C 語(yǔ)言
- 2022-09-13 cmd命令打開(kāi)及切換目錄路徑的實(shí)現(xiàn)_DOS/BAT
- 2022-05-13 類(lèi)實(shí)例化 對(duì)象的內(nèi)存模型 及 內(nèi)存占用分析
- 2022-05-12 databinding 與 RecyclerView.Adapter
- 2022-12-06 詳解Python的整數(shù)是如何實(shí)現(xiàn)的_python
- 2023-01-05 Kotlin協(xié)程Job生命周期結(jié)構(gòu)化并發(fā)詳解_Android
- 最近更新
-
- window11 系統(tǒng)安裝 yarn
- 超詳細(xì)win安裝深度學(xué)習(xí)環(huán)境2025年最新版(
- Linux 中運(yùn)行的top命令 怎么退出?
- MySQL 中decimal 的用法? 存儲(chǔ)小
- get 、set 、toString 方法的使
- @Resource和 @Autowired注解
- Java基礎(chǔ)操作-- 運(yùn)算符,流程控制 Flo
- 1. Int 和Integer 的區(qū)別,Jav
- spring @retryable不生效的一種
- Spring Security之認(rèn)證信息的處理
- Spring Security之認(rèn)證過(guò)濾器
- Spring Security概述快速入門(mén)
- Spring Security之配置體系
- 【SpringBoot】SpringCache
- Spring Security之基于方法配置權(quán)
- redisson分布式鎖中waittime的設(shè)
- maven:解決release錯(cuò)誤:Artif
- restTemplate使用總結(jié)
- Spring Security之安全異常處理
- MybatisPlus優(yōu)雅實(shí)現(xiàn)加密?
- Spring ioc容器與Bean的生命周期。
- 【探索SpringCloud】服務(wù)發(fā)現(xiàn)-Nac
- Spring Security之基于HttpR
- Redis 底層數(shù)據(jù)結(jié)構(gòu)-簡(jiǎn)單動(dòng)態(tài)字符串(SD
- arthas操作spring被代理目標(biāo)對(duì)象命令
- Spring中的單例模式應(yīng)用詳解
- 聊聊消息隊(duì)列,發(fā)送消息的4種方式
- bootspring第三方資源配置管理
- GIT同步修改后的遠(yuǎn)程分支