【加試題】小張為了處理2015年中國主要城市的GDP數據,他把2015年中國主要城市的GDP據存儲在數據庫文件gdp.jye.ai中.他設計了一個Visual Basic程序,程序運行效果如第17題圖所示.在界面的左側列表框List1中顯示按各城市GDP數值,單擊“按人均GDP排序”按鈕(Command1),在右側列表框List2中顯示排序完成后的結果
(按人均GDP值從高到低排序).

實現上述功能的VB代碼如下:
(1)請在空格處填入合適代碼.
Dim conn As New ADODB.Connection
Dim rs As New ADODB.Recordset
Dim n As Integer,i As Integer,j As Integer
Dim t As Long,ts As String
Dim a(1To 200)As Integer
Dim c(1To 200)As String
Dim g(1To 200)As Long
Dim p(1To 200)As Long
Private Sub Form_Load ( )
conn.ConnectionString=“Provider=Microsoft.ACE.OLEDB.12.0;Data Source=“_
& App.Path &“\gdp.jye.ai“
'上面語句中的“_“為語句換行符,表示下一行內容為本行的繼續 conn.Open
Set rs.ActiveConnection=conn rs.Open“SELECT*FROM dGDP“
n=0'Ⅰ處代碼
Do While Not rs.EOF n=n+1 a
(n)=rs.Fields(“GDP排名“).Value c(n)=rs.Fields(“城市“).Value
g(n)=rs.Fields(“GDP“).Value p(n)=rs.Fields(“人均GDP“).Value
List1.AddItem Str(a(n))+““+c(n)+““+_
Str(g(n))+““+Str(p(n))
'上面語句中的“_“為語句換行符,表示下一行內容為本行的繼續
rs.MoveNext Loop rs.Close conn.Close
Set rs=Nothing
Set conn=Nothing
End Sub
Private Sub Command1_Click ( )
For i=1To n-1
For j=①i+1i+1To n
If p(i)<p(j) Then
a(i)=a(i)+a(j)
a(j)=a(i)-a(j)
②a(i)=a(i)-a(j)a(i)=a(i)-a(j)P
ts=c(i)
c(i)=c(j)
c(j)=ts
t=g(i)
g(i)=g(j)
g(j)=t
t=p(i)
p(i)=p(j)
p(j)=t
End If
Next j
Next i
List2.Clear
For i=1To n
List2.AddItem Str(a(i))+““+c(i)+““+_
Str(g(i))+““+Str(p(i))
'上面語句中的“_“為語句換行符,表示下一行內容為本行的繼續
Next i
End Sub
(2)若Ⅰ處代碼n=0改為 n=1程序運行結果將不正確,其原因是n=0改為n=1后,將導致存儲記錄的數組,是從第二個元素開始存儲,最終多了一個GDP為0的記錄n=0改為n=1后,將導致存儲記錄的數組,是從第二個元素開始存儲,最終多了一個GDP為0的記錄.
【考點】對象的屬性、方法和事件;編輯事件處理過程的代碼.
【答案】i+1;a(i)=a(i)-a(j);n=0改為n=1后,將導致存儲記錄的數組,是從第二個元素開始存儲,最終多了一個GDP為0的記錄
【解答】
【點評】
聲明:本試題解析著作權屬菁優網所有,未經書面同意,不得復制發布。
發布:2024/4/20 14:35:0組卷:3引用:1難度:0.1
相似題
-
1.運行列表框對象語句:List1.AddItem=“同學們好!“,會顯示:同學們好!;
發布:2025/1/2 11:30:1組卷:6引用:6難度:0.9 -
2.小張設計了一個“加減運算練習”VB程序.界面如下圖所示.單擊“出題”Command1按鈕顯示兩個運算數和運算符號,并計數.在文本框Text1中輸入計算結果后單擊“判斷”按鈕Command2,如果計算結果正確,則得分加10分,直至完成10題測試.VB程序如下,但加下橫線處代碼有錯,請改正.
Dim n,s As Integer'n為試題計數器,s為得分
Dim a,b As Integer'a,b 為兩個運算數
Dim c As String'c為運算符:“+“表示加法,“-“表示減法
Private Sub Form_Load( )n=0:
s=0
End Sub
Private Sub Command1_Click( )‘出題按鈕
Randomize
n=n+1
If n<11Then
Label1.Caption=“No:“+Str(n)
a=Int(Rnd*100)'a,b為運算數,且要求a不小于b
b=Int(Rnd*100)
If a>bThen t=a:a=b:b=t'(1)
If Rnd>0.5Then c=“+“Else b=“-“'(2)
Label5.Caption=Str(a)+c+Str(b)+“=“
Text1.Text=““
Else
Command1.Caption=“完成測試“
End If
End Sub
Private Sub Command2_Click( )‘判斷按鈕
If c=“+“Then
If a+b=Val(Text1.Text) Then s=s+10
Else
If a+b=Val(Text1.Text)Then s=s+10'(3)
End If
Label3.Caption=“得分:“+Str(s)
End Sub.發布:2025/1/2 9:30:2組卷:6引用:2難度:0.9 -
3.某智能農場啟用了根據土壤濕度自動控制噴淋裝置進行澆水的信息系統,每隔一段時間,系統自動檢測土壤濕度,當土壤濕度低于某個閾值時將自動澆水。小李為統計出某段時間內(不超過100個時間單位)系統自動控制澆水的次數和該時間段內前后兩次啟動自動澆水系統的最大時間間隔單位,小李進行了數據分析,他認為如果某單位時間的土壤濕度比前一單位時間的土壤濕度高并且本單位時間內沒有下雨,則認為啟用了澆水系統。由此他編寫了一個VB程序實現該功能:在文本框Text1中輸入某段時間內的濕度值,在文本框Text2中輸入該段時間內對應的天氣情況,單擊命令按鈕Command1,在文本框Text3中顯示系統自動澆水次數,Text4中顯示前后兩次自動澆水系統啟用的最大時間間隔單位。
(1)在Private Sub Command1_Click( )中,Command1、Click分別表示
(2)實現上述功能的VB程序如下,請在畫線處填入合適的代碼。
(3)程序中加框處代碼有錯,請改正。發布:2025/1/2 11:0:1組卷:0引用:1難度:0.3