正整數(shù)n的階乘,在數(shù)學(xué)中定義為:n!=1×2×3×…×n,如:3!=1×2×3,現(xiàn)在輸入一個(gè)正整數(shù)n(n<=30),計(jì)算出1~n中的每一個(gè)整數(shù)的階乘的精確結(jié)果.小北按照上述要求,設(shè)計(jì)一個(gè)求前n個(gè)正整數(shù)的階乘問題的VB程序,功能如下:在程序中他采用加法代替乘法的方法來計(jì)算階乘,如:3!=2!×3=2!+2!+2!.程序啟動(dòng)后在文本框Text1中輸入n的值,單擊“計(jì)算”按鈕Command1,在列表框List1中輸出前n個(gè)數(shù)的階乘.當(dāng)n=10時(shí),程序運(yùn)行效果如圖所示:
實(shí)現(xiàn)上述功能的VB程序如下請(qǐng)?jiān)跈M線處填入合適的代碼.
Const maxn=80
Dim i As Integer,j As Integer,k As Integer,n As Interger,r As Interger
Dim a(1 To maxn)As Integer,b(1 To maxn)As Integer,s As String
Private Sub Form_Load( ?。?br /> List1.Clear
For i=1 To maxn
a(i)=0
Next i
End Sub
Sub array_sum(j As Integer)'該過程用于計(jì)算 j!,并將j!的精確值按位保存在數(shù)組a中
For k=1 To j-1
For i=1 To maxn
r=a(i)+b(i)a(i)+b(i)
If r>=10 Then a(i+1)a(i+1)=a(i+1)+1
a(i)=r Mod 10
Next i
Next k
End Sub
Private Sub Command1_Click( ?。?br /> n=Val(Text1.Text)
a(1)=1
List1.AddItem“1!=“&Str(a(1))
For j=2 To n
For i=1 To maxn
b(i)=a(i)
Next i
s=““
Call array_sum(j)'該語句用于調(diào)用自定義過程 array_sum
s=s+Str(j)+“!=“
k=maxn
Do While a(k)=0
k=k-1k=k-1
Loop
For i=k To 1 step-1
s=s+Str(a(i))
Next i
List1.AddItem s
Next j
End Sub.
【考點(diǎn)】編輯事件處理過程的代碼.
【答案】a(i)+b(i);a(i+1);k=k-1
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:2引用:1難度:0.1
相似題
-
1.學(xué)校舉辦了“語文作文現(xiàn)場賽”,參賽同學(xué)成績存儲(chǔ)在文本文件“gra.jye.ai”中,如左圖所示(每一行記錄一位同學(xué)的姓名和成績,以“:”分隔)。陳老師利用Python程序?qū)ψ魑某煽冞M(jìn)行處理,統(tǒng)計(jì)出各個(gè)分?jǐn)?shù)等級(jí)的人數(shù),并輸出結(jié)果。程序運(yùn)行界面如右圖所示。
實(shí)現(xiàn)上述功能的Python程序如下,請(qǐng)?jiān)趧澗€處填入合適的代碼。發(fā)布:2024/12/17 2:0:1組卷:6引用:2難度:0.3 -
2.有如下Python程序段:
執(zhí)行該程序段,輸入字符串“abcdefg”,則輸出的結(jié)果是( ?。?/h2>發(fā)布:2024/12/20 6:30:1組卷:2引用:3難度:0.4 -
3.試題描述的內(nèi)容:
一個(gè)單窗體VB程序的運(yùn)行界面如圖所示。下列說法正確的是( ?。?br />(1)窗體內(nèi)有1個(gè)按鈕
(2)窗體內(nèi)有2個(gè)文本框
(3)窗體內(nèi)有3個(gè)標(biāo)簽
(4)該窗體的標(biāo)題(Caption)屬性值是“加法計(jì)算器”發(fā)布:2024/12/20 20:0:2組卷:1引用:1難度:0.6
把好題分享給你的好友吧~~