小李編寫一個統(tǒng)計學生選考科目的VB程序,算法的基本思想是:檢查每位學生選課組合的編碼是否有效,對有效選擇結果進行科目統(tǒng)計,根據(jù)各科次占有效人數(shù)的百分率求出各科排名.程序運行時,單擊“顯示”按鈕Command1,學生選課數(shù)據(jù)顯示在列表框list1中,各科編號及對應科目名稱顯示列表框list2中,單擊“統(tǒng)計”按鈕Command2,選課結果按各科百分率由高到低顯示在列表框list3中,程序運行結果如圖所示.
實現(xiàn)上述功能的VB程序如下,請回答下列問題:
(1)學生選課的編碼數(shù)據(jù)存儲在數(shù)據(jù)表中,其字段名為 subjectsubject.
(2)請在橫線處填入合適的代碼.
Dim ach(1 to 500)As String’存儲各學生選課編碼
Dim bno(1 to 10)As Integer’存儲各科目編號
Dim bname (1 to 10)As String’存儲各科目名稱
Dim bnum(1 to 10)As Integer’存儲各科目被選次數(shù)
Dim bmc(1 to 10)As Integer’存儲各科目被選的名次
Dim n As Integer,num As Integer
Private Sub Commandl-Click( ?。?br /> Dim i As Integer,km As String
km=“物理化學生物政治歷史地理技術“
Dim cn As New ADODB.Connection,rs As New ADODB.Recordset,spl As String
cn.Open“provider=Microsoft.jye.ai.4;Data Source=“+App.Path+“\students.jye.ai“
rs.Open“select*from choose“,cn
Do Whole Not rs.EOF
n=n+1:ach(n)=rs.Fields(“subject“):rs.MoveNext
Loop
rs.Close
cn.Close
Set rs=Nothing
Set cn=Nothing
For i=1 to 7
bno(i)=i
bname(i)=Mid(km,(i-1)*2+1,2)
List2.AddItem TR(bno(i))+“---“+bname(i)
Next i
End Sub
Private Sub Command2-Click( ?。?br /> Dim i As Integer,j As Integer,k As Integer
Dim c As String,per As Integer
For i=1 to n
If check(ach(i))=True Then
For j=1 to 3
c=Mid(ach(i),j,1)
bnum(Val(c))=bnum(Val(c))+1bnum(Val(c))+1
Next j
num=num+1
End If
Next i
i=1
Do While i<=7’該循環(huán)得到各學科被選人數(shù)的名次
bmc(i)=1
For j=1 to 7
If bnum(j)>bnum(i) Then bmc(i)=bmc(i)+1bmc(i)=bmc(i)+1
Next j
i=i+1
Loop
For i=1 to 7
For j=1 to 7
If i=bmc(j)i=bmc(j)Then
per=In(bnum(j)*100/num*100)/100
List3.AddItem Str(bno(j))+“---“+Str(per)+“%“
End If
Next i
End Sub
Function check(s As String) As Boolean
’代碼略!若學生選代碼有效,函數(shù)返回True,否則返回False
End Function.
【考點】編輯事件處理過程的代碼.
【答案】subject;bnum(Val(c))+1;bmc(i)=bmc(i)+1;i=bmc(j)
【解答】
【點評】
聲明:本試題解析著作權屬菁優(yōu)網(wǎng)所有,未經書面同意,不得復制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:0引用:1難度:0.3
相似題
-
1.根據(jù)AQI值判斷城市的空氣質量。若城市的AQI值(整數(shù))不超過100則空氣質量優(yōu)良,否則空氣質量有污染。當輸入的AQI值為-1時則退出程序。不要更改程序結構,將題中的①②③④填入正確的語句。
city=input(“請輸入城市名:”)
AQI=int(input(“請輸入空氣質量指數(shù)AQI的值:”))
①______ AQI!=-1:
if ②______:
print(city,“的空氣質量優(yōu)良。”)
③______:
print(city,“的空氣質量有污染。”)
city=input(“請輸入城市名:”)
AQI=④(input(“請輸入空氣質量指數(shù)AQI的值:”))
(1)序號①答案為
A.if
B.while
C.for
D.def
(2)序號②答案為
A.AQI>=100
B.AQI<=100
C.AQI>100
D.AQI<100
(3)序號③答案為
A.elif
B.break
C.if
D.else
(4)序號④答案為
A.int
B.float
C.str
D.else發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4 -
2.一球從100米高度自由落下,每次落地后反跳回原高度的一半,再下落。編寫一個C程序,求它在第10次落地時,其經過了多少米?第10次反彈多高?
發(fā)布:2025/1/2 11:0:1組卷:0引用:3難度:0.3 -
3.利用海倫公式求解三角形面積。已知a,b,c為三角形的三條邊長,p為三角形的半周長,即p=(a+b+c)/2,計算此三角形面積S的海倫公式為:。不要更改程序結構,將題中的①②③填入正確的語句。
import math#導入數(shù)學模塊
def hl(a,b,c):#定義求三角形面積的函數(shù)
p=①
s=math.jye.ai(②)#sqrt用于計算算術平方根
return ③#返回面積的值
a,b,c=3,4,5#邊長依次賦值
print(“此三角形的面積S為:“,hl(a,b,c))
A. (a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C. (a+b+c)*2 D.s
(2)序號②答案為
A.(a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C.(a+b+c)*2 D.(3+4+5)/2
(3)序號③答案為
A.p B.s
C.p*(p-a)*(p-b)*(p-c) D.0發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4
把好題分享給你的好友吧~~