第5章-設(shè)計循環(huán)結(jié)構(gòu)程序_第1頁
第5章-設(shè)計循環(huán)結(jié)構(gòu)程序_第2頁
第5章-設(shè)計循環(huán)結(jié)構(gòu)程序_第3頁
第5章-設(shè)計循環(huán)結(jié)構(gòu)程序_第4頁
第5章-設(shè)計循環(huán)結(jié)構(gòu)程序_第5頁
已閱讀5頁,還剩46頁未讀 繼續(xù)免費閱讀

下載本文檔

版權(quán)說明:本文檔由用戶提供并上傳,收益歸屬內(nèi)容提供方,若內(nèi)容存在侵權(quán),請進行舉報或認領(lǐng)

文檔簡介

第5章設(shè)計循環(huán)結(jié)構(gòu)程序1循環(huán)結(jié)構(gòu)又稱重復(fù)結(jié)構(gòu)。本章主要介紹:邏輯表達式For/Next語句Do/Loop語句While/Wend語句循環(huán)的嵌套使用。2循環(huán)結(jié)構(gòu)是根據(jù)條件來決定某段代碼是否重復(fù)執(zhí)行。循環(huán)結(jié)構(gòu)中一種常用的流程可以表示如圖:條件滿足就執(zhí)行a塊程序段然后再進行條件判別如果滿足條件,則繼續(xù)執(zhí)行a塊程序段直到條件不滿足,才執(zhí)行a塊后面的程序。5.1概述3其中的a程序塊段稱為循環(huán)體。條件使用邏輯表達式。循環(huán)的另一種形式是把判斷條件放在循環(huán)體之后。4循環(huán)結(jié)構(gòu)中有兩個基本問題需要考慮:(1)條件必須明確,能使循環(huán)過程正常結(jié)束(2)循環(huán)體內(nèi),必要時可改變控制循環(huán)的條件改變可能導(dǎo)致循環(huán)結(jié)束改變也可能導(dǎo)致循環(huán)進入無休止的狀態(tài)(死循環(huán))。5循環(huán)有兩種類型:計數(shù)控制控制累計執(zhí)行循環(huán)體的次數(shù)次數(shù)已到則結(jié)束循環(huán)如1+2+3+…+100或98+96+94+…+4+2事態(tài)控制由某些條件決定循環(huán)結(jié)束。如計算一系列正整數(shù)之和,遇負數(shù)停止循環(huán)。也可以在一個循環(huán)過程中同時使用這兩種類型6【例5-1】設(shè)計一個判斷素數(shù)的程序。若不是素數(shù),要求分解為a*b的形式控件:1個文本框和1個命令按鈕事件:命令按鈕的Click。首先要了解什么是素數(shù)。素數(shù)是指除了1和自身外,不能被其它整數(shù)整除的正整數(shù)。判斷A是否為素數(shù)的基本方法是:將A分別除以2、3、……、A-1,若都不能整除,則它為素數(shù)。判斷A被i整除可以采用表達式:AModi=0或:A/i=A\i或:A/i=Int(A/i)5.2判斷素數(shù)7OptionExplicit

PrivateSubCommand1_Click()

DimAAsLong,iAsInteger'A存放要判斷的數(shù)。i取值為2~A-1

DimFlagAsBoolean'Flag作素數(shù)標(biāo)志,F(xiàn)alse時,表示不是素數(shù)

A=Val(Text1.Text)

Flag=True'先設(shè)A是素數(shù),當(dāng)A<2或能被i整除時,再置為False

IfA<2Then

Flag=False'A<2,不是素數(shù)

Else

i=2

DoWhilei<=A-1

IfAModi=0ThenFlag=False:ExitDo'A能被i整除,則不是素數(shù)

i=i+1

Loop

EndIf

IfFlagThen

MsgBoxA&"是素數(shù)",,"信息"

Else'A表示成兩數(shù)之積

MsgBoxA&"不是素數(shù)"&Chr(13)&A&"="&i&"*"&A/i,,"信息"

EndIf

EndSub5.2判斷素數(shù)----程序8說明:程序中,也可以不設(shè)標(biāo)志變量,在最后判斷i是否超過終值A(chǔ)-1,若超過終值則表示直到循環(huán)完成,還沒遇到一個能被整除的整數(shù),即它是素數(shù);否則它就不是素數(shù)。當(dāng)A能被其中一個i整除時,A肯定不是素數(shù),所以沒有必要再測試下一個i,因此使用ExitDo退出循環(huán)。在使用ExitDo退出循環(huán)的時候,沒有改變i的值,故A能被該i整除,即A可以表示成A=i*(A/i)。事實上只要判斷A能否被2、3、……、Sqr(A)整除即可。9邏輯運算使用邏輯運算符VB提供了多個邏輯運算符,有:非(Not)、與(And)、或(Or)異或(Xor)、等價(Eqv)、蘊含(Imp)。1.基本格式Not為一元運算符,其它均為二元運算符。格式:

Not表達式表達式1邏輯運算符表達式2(除Not外)一個邏輯表達式可用一個或多個邏輯運算符。如:A>0AndB>0AndC>02.?dāng)?shù)據(jù)類型邏輯運算的數(shù)據(jù)及結(jié)果均為布爾類型。5.3進行邏輯運算103.運算方式

4.優(yōu)先級115.邏輯表達式舉例(1)設(shè)變量Name1的值為“王小華”、變量Addr的值為“上?!?,則

表達式:Name1=“王小華”O(jiān)rAddr="杭州"值:True表達式:Name1=“王小華”AndAddr="滬"值:False(2)寫出數(shù)學(xué)表達式0<x<10對應(yīng)的VB表達式。

VB表達式應(yīng)為:x>0Andx<1012(3)描述Name1的值不等于“王小華”的表達式。該表達式可寫為:

Name1<>"王小華"或:NotName1="王小華"(4)X=3、Y=4、Z=5,求表達式X>2XorY<0OrZ>X+1的值。

執(zhí)行次序如圖所示,最終值為False。13閏年的條件是:能被4整除,但不能被100整除;或能被400整除。設(shè)變量Y存放年份,則該邏輯表達式應(yīng)為:YMod4=0AndYMod100<>0OrYMod400=0【例5-2】設(shè)計程序,要求對文本框的年份判斷是否為閏年,并在標(biāo)簽中顯示相應(yīng)的信息。14程序代碼如下:

OptionExplicit

PrivateSubCommand1_Click()

DimYAsInteger

IfCommand1.Caption="閏年判斷"Then'閏年判斷

Y=Val(Text1.Text)

IfYMod4=0AndYMod100<>0OrYMod400=0Then

Label1.Caption="是閏年"

Else

Label1.Caption="不是閏年"

EndIf

Command1.Caption="清除"

Else'清除

Text1.Text="":Label1.Caption="":Command1.Caption="閏年判斷"

Text1.SetFocus

EndIf

EndSub5.3進行邏輯運算-閏年判斷155.4.1For/Next語句使用For/Next語句可以方便地實現(xiàn)計數(shù)循環(huán)For/Next由For語句、循環(huán)體、Next語句組成。格式:

For循環(huán)控制變量=初值To終值[Step步長]

[循環(huán)體]

Next[循環(huán)控制變量]5.4使用For/Next循環(huán)語句161.執(zhí)行過程

(1)將初值送至循環(huán)控制變量

(2)判斷循環(huán)控制變量的值是否超過終值:若未超過終值,執(zhí)行步驟(3);超過終值執(zhí)行步驟(5)。

(3)執(zhí)行循環(huán)體。

(4)遇到Next,使循環(huán)控制變量加上步長再送入循環(huán)控制變量中,轉(zhuǎn)步驟(2)。

(5)循環(huán)終止,執(zhí)行Next語句后面的語句。

注意:其中“超過終值”不一定是大于終值。172.關(guān)于格式省略“Step步長”則默認為“Step1”。初值、終值、步長分別控制循環(huán)變量的起始值、終止值和增量。For和Next必須成對出現(xiàn)。Next后若有循環(huán)控制變量,則必須與For中的相同。建議Next后不要省略循環(huán)控制變量,以有利于閱讀程序183.關(guān)于循環(huán)體循環(huán)體是一條或多條語句可以包括分支結(jié)構(gòu)和循環(huán)結(jié)構(gòu)可以寫成一行或多行。循環(huán)體中可以引用循環(huán)控制變量,也可以不引用。但不要隨便修改循環(huán)控制變量的值,以防引起循環(huán)混亂。4.強行終止死循環(huán)使用Ctrl+Break可以暫停程序運行再使用VB工具欄上的“結(jié)束”按鈕終止程序執(zhí)行。19【例5-3】輸入10個非負整數(shù),求所有偶數(shù)之和。

假定存放和的變量為Sum,先讓Sum=0。然后可采用以下方法:

將第1個數(shù)送入A,如果A是偶數(shù),則讓Sum加上A,否則Sum不變。

……

將第10個數(shù)送入A,如果A是偶數(shù),則讓Sum增加A,否則Sum不變。

最終得到的Sum就是和。由此可見,每步都做著同樣的工作,即:

將第i個數(shù)送入A,如果A是偶數(shù),則讓Sum增加A,否則Sum不變。

20

OptionExplicit

PrivateSubCommand1_Click()'輸入10個非負整數(shù),求偶數(shù)和。

DimSumAsLong,iAsInteger

DimAAsInteger

Sum=0'賦初值,注意位置

Fori=1To10

A=Val(InputBox("請輸入第"&i&"個數(shù):","輸入非負整數(shù)"))

IfAMod2=0ThenSum=Sum+A

Nexti

MsgBox"Sum="&Sum

EndSub

一個好的程序,應(yīng)該為自己用于累加、累乘等的變量賦初值。21【例5-4】求表達式值。x、n由鍵盤輸入。這是一個求和的例子。它由n項構(gòu)成,能表示成Sum=Sum+Item的形式第i項等于第i-1項乘以X/(i+1),即Item=Item*X/(i+1)故循環(huán)體可由Item=Item*X/(i+1)和Sum=Sum+Item構(gòu)成。初值問題:Sum初值為0,Item初值應(yīng)為1。

為防止溢出,Item和Sum聲明為雙精度型。

程序運行結(jié)果:

當(dāng)X=6,N分別為1、2、3時,其和分別為3、9、18。22PrivateSubCommand1_Click()

DimSumAsDouble,ItemAsDouble,iAsInteger

DimNAsInteger,XAsDouble

N=Val(InputBox("請輸入項數(shù):"))

X=Val(InputBox("X="))

Sum=0:Item=1

Fori=1ToN

Item=Item*X/(i+1)

Sum=Sum+Item

Nexti

MsgBox"x/2!+x^2/3!+...="&Sum,,"信息"

EndSub235.4.2ExitFor語句循環(huán)中,中途退出循環(huán),稱為跳出循環(huán)。跳出For/Next循環(huán)的語句就是ExitFor。跳出循環(huán)后,將執(zhí)行Next語句后面的語句。ExitFor語句一般往往與If語句合用。如:

IfA>=2Then'素數(shù)判斷

Fori=2ToInt(Sqr(A))

IfAModi=0ThenExitFor'A能被i整除,不是素數(shù),退出For循環(huán)

Nexti

Ifi>Int(Sqr(A))Then'表示A不能被2~Int(Sqr(A))中的數(shù)整除

PrintA;"是素數(shù)"

Else'此時表示程序運行是通過ExitFor轉(zhuǎn)出來的

PrintA;"不是素數(shù)"

EndIf

Else

PrintA;"不是素數(shù)"

EndIf245.5.1Do/Loop語句對只知道循環(huán)終止條件,可采用Do/Loop循環(huán)For/Next語句可改寫成Do/Loop循環(huán),反之則不然。Do/Loop語句有五種表示形式,它們的格式為:

5.5使用Do/Loop循環(huán)語句251.執(zhí)行過程

(1)對格式一和二,VB將先判斷條件,再執(zhí)行循環(huán)體。

(2)對格式三和四,先執(zhí)行循環(huán)體,再判斷條件。循環(huán)體至少執(zhí)行一次。

(3)對用While的語句,當(dāng)條件滿足(True)時,執(zhí)行循環(huán)體。

(4)對用Until的語句,當(dāng)條件不滿足(False)時,執(zhí)行循環(huán)體。

(5)格式五的循環(huán)體內(nèi)必須存在ExitDo語句,否則會出現(xiàn)死循環(huán)。

若程序運行出現(xiàn)死循環(huán),同樣可用CtrlBreak暫停程序執(zhí)行。262.關(guān)于格式

(1)條件一般應(yīng)為關(guān)系或邏輯表達式,一般應(yīng)有變量。

(2)Do和Loop必須成對出現(xiàn)3.關(guān)于循環(huán)體循環(huán)體是一條或多條語句可以包括分支結(jié)構(gòu)和循環(huán)結(jié)構(gòu)??梢詫懗梢恍谢蚨嘈?。循環(huán)體中應(yīng)有改變循環(huán)條件的語句,以避免出現(xiàn)死循環(huán)。27PrivateSubCommand1_Click()

DimNAsInteger,ResultAsDouble

DimiAsInteger

N=Val(InputBox("n="))

Result=1

Fori=1ToN

Result=Result*i

Nexti

MsgBoxN&"!="&Result

EndSub0PrivateSubCommand2_Click()

DimNAsInteger,ResultAsDouble

DimiAsInteger

N=Val(InputBox("n="))

Result=1:i=1

DoWhilei<=N

Result=Result*i

i=i+1

Loop

MsgBoxN&"!="&Result

EndSubPrivateSubCommand3_Click()

DimNAsInteger,ResultAsDouble

DimiAsInteger

N=Val(InputBox("n="))

Result=1:i=1

DoUntili>N

Result=Result*i

i=i+1

Loop

MsgBoxN&"!="&Result

EndSubPrivateSubCommand4_Click()

DimNAsInteger,ResultAsDouble

DimiAsInteger

N=Val(InputBox("n="))

Result=1:i=1

Do

Result=Result*i

i=i+1

LoopWhilei<=N

MsgBoxN&“!=”&Result

EndSub5.5.1Do/Loop語句-編程序:求n!28【例5-6】在文本框中輸入兩個整數(shù),求它們的最大公約數(shù)和最小公倍數(shù)。求最大公約數(shù)可用輾轉(zhuǎn)相除法。該方法的基本思想是使用帶余除法:(1)A除以B,得余數(shù)為R1;(2)若R1=0,則B為最大公約數(shù)。

若R1≠0,則B賦值給A,R1賦值給B,求余數(shù)R2;

若R2≠0,則繼續(xù)以上步驟。29(3)經(jīng)過有限(n+1)步后,Rn+1=0。這時A和B的最大公約數(shù)是Rn。最小公倍數(shù)為A*B/Rn。該算法循環(huán)次數(shù)未知,但循環(huán)條件已知:余數(shù)不為0。因此適用于Do/Loop語句編程。其循環(huán)體為:把上一個B作為新的A,把上一個余數(shù)作為新的B,求出新余數(shù)。305.5.1Do/Loop語句—求最大公約數(shù)和最小公倍數(shù)PrivateSubCommand1_Click()

DimAAsLong,BAsLong,RAsLong

A=Val(Text1.Text)

B=Val(Text2.Text)

R=AModB

DoWhileR<>0

A=B:B=R

R=AModB

Loop

MsgBox"最大公約數(shù)="&B

MsgBox"最小公倍數(shù)="&Val(Text1.Text)*Val(Text2.Text)/BEndSub

如果s在兩個文本框中分別輸入351和675,單擊命令按鈕后,得出最大公約數(shù)為27,最小公倍數(shù)為8775。31【例5-7】編程:輸入一批非負數(shù),當(dāng)輸入負數(shù)時,表示輸入結(jié)束。求這批非負數(shù)據(jù)的最大值、最小值和平均值。由于輸入的個數(shù)不確定,故應(yīng)采用Do/Loop語句。本題關(guān)鍵在于如何設(shè)置最大值、最小值的初值。32PrivateSubCommand1_Click()

DimXAsInteger,MinAsInteger,MaxAsInteger

DimNAsInteger,AverageAsSingle'N作為計數(shù),存放項數(shù)

X=Val(InputBox("X=")):Max=X:Min=X'最大最小值初值

N=0:Average=0

DoWhileX>=0

IfX>MaxThenMax=X

IfX<MinThenMin=X

N=N+1

Average=Average+X'Average暫存數(shù)據(jù)和,最后再除N

X=Val(InputBox("X="))'從第2個開始輸入

Loop

IfN<>0ThenAverage=Average/N

Print"Max=";Max,"Min=";Min,"Average=";Round(Average,3)EndSub當(dāng)輸入23、41、35、61、12、1、7、-1后,運行結(jié)果:Max=61Min=1Average=25.714335.5.2ExitDo語句ExitDo是跳出Do/Loop循環(huán)的語句跳出循環(huán)后,將執(zhí)行Loop語句后面的語句。ExitDo語句同樣也往往與If語句合用如求階乘的程序片斷為:

N=Val(InputBox("n="))

Result=1:i=1

Do

Result=Result*i

i=i+1:Ifi>NThenExitDo

Loop

MsgBoxN&"!="&Result34While/Wend語句的作用與DoWhile條件/循環(huán)體/Loop相同。格式:

While條件

[循環(huán)體]

Wend執(zhí)行過程:先計算條件的值,若條件的值為True,執(zhí)行循環(huán)體,否則執(zhí)行Wend語句后面的語句。While和Wend必須成對出現(xiàn)循環(huán)體中必須要有設(shè)法改變循環(huán)條件的語句While/Wend語句沒有對應(yīng)的跳出語句。5.6使用While/Wend循環(huán)語句35【例5-8】編程:求π的值。有關(guān)π的級數(shù)公式為:要求逐項累加,直到最后一項<0.0000001時,求π。因沒有確定項數(shù),故可用Do/Loop或While/Wend可設(shè)一個變量Sign作為各項的符號,在循環(huán)中讓Sign=-Sign,可以達到一次正、一次負的目的。為達到較為精確的值,變量大多聲明為雙精度型36本例中變量Pi、Sum、Item、N、Precision分別存放π、累計和、項值、項中分母值和精度。PrivateSubCommand1_Click()

DimPiAsDouble,SumAsDouble,ItemAsDouble

DimNAsLong,PrecisionAsDouble,SignAsInteger

N=1:Item=1/N:Sum=0:Sign=1

Precision=Val(InputBox(“請輸入精度:”,“輸入數(shù)據(jù)”,“0.0000001”))

WhileItem>=Precision

Sum=Sum+Sign*Item

N=N+2

Item=1/N

Sign=-Sign

Wend

Pi=4*Sum

Print“π=”;Pi

EndSub

在單擊命令按鈕后,若精度用缺省值0.0000001,則顯示=3.1415924535898。37循環(huán)結(jié)構(gòu)中可以嵌套循環(huán)當(dāng)循環(huán)體中包含了循環(huán)時,稱為循環(huán)嵌套,或稱為多重循環(huán)。循環(huán)體中包含的循環(huán)語句可以與外循環(huán)相同,也可以不同。嵌套一層稱為二重循環(huán)。多重循環(huán)中遇到ExitFor(Do),只能跳出當(dāng)前一層循環(huán)。5.7如何實現(xiàn)多重循環(huán)控制38【例5-9】窗體上顯示3~100之間的所有素數(shù)。每行顯示5個。前面的例子中判斷A是否為素數(shù)是一重循環(huán)?,F(xiàn)讓A分別等于3、5、7、……、97、99就可以了。為了每行顯示5個,設(shè)置一個計數(shù)變量Count。PrivateSubCommand1_Click()

DimAAsInteger,iAsInteger,CountAsInteger

Count=0'素數(shù)個數(shù)計數(shù)變量

Print"以下數(shù)據(jù)為素數(shù):"

ForA=3To99Step2

Fori=2ToInt(Sqr(A))

IfAModi=0ThenExitFor'被整除

Nexti

Ifi>Int(Sqr(A))Then

Count=Count+1:PrintA,

IfCountMod5=0ThenPrint'換行

EndIf

NextA

EndSub39【例5-10】

在窗體上如圖圖案,它由“*”組成。分析:上三角形中,第I行有I個,可使用循環(huán):ForJ=1ToI:Print"*";:NextJ因每行起點不同,而且一行結(jié)束后要換行,所以在J循環(huán)的前后各有一Print。這樣的行有7行,故外循環(huán)使I從1至7。下三角形,操作過程與上三角相似40PrivateSubCommand1_Click()

DimIAsInteger,JAsInteger

Cls

ForI=1To7

PrintSpc(20-I);'打印時空20-i格

ForJ=1ToI

Print"*";

NextJ

Print'用于換行

NextI

ForI=6To1Step-1

PrintSpc(20-I);

ForJ=1ToI

Print"*";

NextJ

Print

NextI

EndSub

5.7如何實現(xiàn)多重循環(huán)控制-顯示圖案415.8.1遞推法【例5-11】

有一個數(shù)列,前兩項是1、1,第三項是前二項之和,以后每一項都是前二項之和。即為:1、1、2、3、5、8、13、21,34……。要求輸出該數(shù)列的前30項。該數(shù)列又稱斐波那契數(shù)列。由“兔子問題”引發(fā)這是一個遞推問題所謂遞推關(guān)系是指一串函數(shù)之間的關(guān)系,它把每一個函數(shù)表示為前k個函數(shù)的線性組合。本題中k=2。解決遞推問題必須具備兩個條件:

(1)

有初始值,如F1=1、F2=1

(2)

存在遞推關(guān)系。如Fn=Fn-1+Fn-2(n>2)在程序中一般設(shè)置二或三個變量就可以了。程序中用F1、F2、F3表示三個數(shù),在循環(huán)中,它們不斷用新值代替舊值。這種操作稱為迭代,5.8程序舉例42程序代碼如下:

PrivateSubCommand1_Click()

DimF1AsLong,F2AsLong,F3AsLong

DimiAsInteger

Cls

F1=1:F2=1

PrintF1,F2,

Fori=3To30

F3=F1+F2

PrintF3,

IfiMod4=0ThenPrint'每行顯示4個數(shù)

F1=F2:F2=F3'用新值代替舊值

Next

EndSubF1和F2始終作為前兩個數(shù),F(xiàn)3作為新產(chǎn)生的數(shù)因第24個月兔子數(shù)已超過32767對,故變量聲明為Long435.8.2窮舉法【例5-12】

我國古代數(shù)學(xué)家在《算經(jīng)》中出了一道題:“雞翁一,值錢五;雞母一,值錢三;雞雛三,值錢一。百錢買百雞,問雞翁、母、雛各幾何?”即:當(dāng)時用100元錢買100只雞,其中公雞每只5元,母雞每只3元,小雞3只1元,問可買公雞、母雞、小雞各多少只?設(shè)公雞X只,母雞Y只,小雞Z只,列出方程式:

X+Y+Z=100

5X+3Y+Z/3=1002個方程求3個未知數(shù),無法用代數(shù)方法求解可將X、Y、Z分別為0~100的每一種可能性都去試一下,如符合,則就是其中的一種購買方案。列舉所有可能的方案,找出符合要求的,這樣的算法稱為窮舉法。44可測試方案分別為: 0、0、0;0、0、1;……;0、0、100;1、0、0;1、0、1;……;1、0、100;……;100、100、0;100、100、1;……;100、100、100事實上當(dāng)X和Y確定時,Z可以用100-X-Y求得,因此可以把三重循環(huán)改為二重循環(huán)。

PrivateSubCommand1_Click()

DimXAsInteger,YAsInteger,ZAsInteger

Print"公雞","母雞","小雞"

ForX=0To100

ForY=0To100

Z=100-X-Y

If5*X+3*Y+Z/3=100ThenPrintX,Y,Z

NextY

NextX

EndSub事實上X和Y的循環(huán)可分別為0到20和0到33455.8.3求水仙花數(shù)【例5-13】

求數(shù)100~999所有滿足:數(shù)X=數(shù)X個位、十位、百位的立方和。如:153=1*1*1+5*5*5+3*3*3說明:該程序主要是能分出個位、十位、百位PrivateSubCommand1_Click()

DimiAsInteger

DimN1AsInteger,N2AsInteger,N3AsInteger

Fori=100To999

N1=i\100 '求百位

N2=(i-N1*100)\10 '求十位

N3=iMod10 '求個位

Ifi=N1^3+N2^3+N3^3Then '計算水仙花數(shù)

Printi;"=";N1;"^3+";N2;"^3+";N3;"^3"

EndIf

Next

EndSub

465.8.4驗證哥德巴赫猜想【例5-14】

輸入一個大于等于6的偶數(shù),將它分解為兩個素數(shù)之和。對每一個大于等于6的偶數(shù)N都可表示成:N=3+(N-3)、N=4+(N-4)、N=5+(N-5)、……、N=(N-3)+3,即A、B的范圍為3~N-3由于大于2的偶數(shù)不是素數(shù),處理前可以去掉這些數(shù),由于3+(N-3)和(N-3)+3是一致的,故A的范圍為3~N/2,B=N-A。程序設(shè)計思路:當(dāng)輸入一個大于等于6的偶數(shù)N后,讓A在3~N/2的奇數(shù)范圍內(nèi)循環(huán),若A是素數(shù),則求出B=N-A,再判斷B是否為素數(shù),若B也是素數(shù),則輸出A和B。47PrivateSubCommand1_Click()

DimAAsLong,BAsLong,NAsLong,iAsInteger,jAsInteger

Do'該循環(huán)是為了必須獲得一個大于等于6的偶數(shù)

N=Val(InputBox("請輸入一個大于6的偶數(shù)"))

Print"輸入的數(shù)為"&N

LoopWhileN/2<>N\2OrN<6

ForA=3ToN/2Step2'步長為2是只判斷偶數(shù)

Fori=2ToSqr(A)'判斷A是否為素數(shù)

IfAModi=0ThenExitFor

Nexti

Ifi>Sqr(A)Then'若A是素數(shù)

B=N-A'求出B

Forj=2ToSqr(B)'判斷B是否也為素數(shù)

IfBModj=0ThenExitFor

Nextj

Ifj>Sqr(B)Then'若B也是素數(shù)

Pri

溫馨提示

  • 1. 本站所有資源如無特殊說明,都需要本地電腦安裝OFFICE2007和PDF閱讀器。圖紙軟件為CAD,CAXA,PROE,UG,SolidWorks等.壓縮文件請下載最新的WinRAR軟件解壓。
  • 2. 本站的文檔不包含任何第三方提供的附件圖紙等,如果需要附件,請聯(lián)系上傳者。文件的所有權(quán)益歸上傳用戶所有。
  • 3. 本站RAR壓縮包中若帶圖紙,網(wǎng)頁內(nèi)容里面會有圖紙預(yù)覽,若沒有圖紙預(yù)覽就沒有圖紙。
  • 4. 未經(jīng)權(quán)益所有人同意不得將文件中的內(nèi)容挪作商業(yè)或盈利用途。
  • 5. 人人文庫網(wǎng)僅提供信息存儲空間,僅對用戶上傳內(nèi)容的表現(xiàn)方式做保護處理,對用戶上傳分享的文檔內(nèi)容本身不做任何修改或編輯,并不能對任何下載內(nèi)容負責(zé)。
  • 6. 下載文件中如有侵權(quán)或不適當(dāng)內(nèi)容,請與我們聯(lián)系,我們立即糾正。
  • 7. 本站不保證下載資源的準(zhǔn)確性、安全性和完整性, 同時也不承擔(dān)用戶因使用這些下載資源對自己和他人造成任何形式的傷害或損失。

評論

0/150

提交評論