【加試題】Excel 篩選功能中,有一種篩選方式是篩選出最大或最小的n項(xiàng).當(dāng)數(shù)據(jù)項(xiàng)中有相同項(xiàng)時(shí),篩選出來(lái)的數(shù)據(jù)條數(shù)則可能會(huì)超過(guò)設(shè)定的項(xiàng)數(shù),如圖1所示,設(shè)置篩選條件為最大的5項(xiàng),由于有4 個(gè)“87”的值并列第四,因此最后篩選結(jié)果就有7 條,而不應(yīng)該是5條.
![](https://img.jyeoo.net/quiz/images/201708/83/8dee3e39.png)
現(xiàn)利用VB 編寫(xiě)一個(gè)類似功能的程序.功能如下:數(shù)組xh、kh 和cj 分別存儲(chǔ)了序號(hào)、考號(hào)和成績(jī)數(shù)據(jù),窗體加載時(shí),序號(hào)、考號(hào)和成績(jī)顯示在列表框list1中.在文本框Text1中輸入數(shù)值N,點(diǎn)擊“篩選”按鈕,可以將成績(jī)最大的前 N 項(xiàng)篩選出來(lái),并按由大到小的順序顯示在列表框list2 中.程序運(yùn)行界面如圖2所示.
實(shí)現(xiàn)上述功能的VB代碼如下,但加框處代碼有錯(cuò),請(qǐng)改正.
Dim num As Integer
Dim xh(1 To 1000)As String
Dim kh(1 To 1000)As String
Dim cj(1 To 1000)As Integer
Private Sub Form_Load( )
’本過(guò)程從數(shù)據(jù)庫(kù)中將序號(hào)、考號(hào)、成績(jī)分別存入
數(shù)組 xh、kh、cj 中,并將人數(shù)賦值給了 num
’代碼略
End Sub
Private Sub Command1_Click( )
Dim N As Integer,i As Integer,j As Integer
Dim t1 As String,t2 As Integer
N=Val(Text1.Text)
List2.Clear
For i=1 To N
k=i
![](https://img.jyeoo.net/quiz/images/201708/83/fa219991.png)
If cj(k)<cj(j) Then k=j
Next j
If k<>i Then
t1=xh(i):xh(i)=xh(k):xh(k)=t1
t1=kh(i):kh(i)=kh(k):kh(k)=t1
t2=cj(i):cj(i)=cj(k):cj(k)=t2
End If
List2.AddItem xh(i)+““+kh(i)+““+Str(cj(i))
Next i
’以下代碼是處理可能存在的重復(fù)項(xiàng)
For i=N+1 To num
![](https://img.jyeoo.net/quiz/images/201708/83/77e13d99.png)
List2.AddItem xh(i)+““+kh(i)+““+Str(cj(i))
End If
Next i
End Sub.
【考點(diǎn)】編輯事件處理過(guò)程的代碼;冒泡排序算法及其實(shí)現(xiàn).
【答案】見(jiàn)試題解答內(nèi)容
【解答】
【點(diǎn)評(píng)】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書(shū)面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/6/27 10:35:59組卷:4引用:1難度:0.1
相似題
-
1.一球從100米高度自由落下,每次落地后反跳回原高度的一半,再下落。編寫(xiě)一個(gè)C程序,求它在第10次落地時(shí),其經(jīng)過(guò)了多少米?第10次反彈多高?
發(fā)布:2025/1/2 11:0:1組卷:0引用:3難度:0.3 -
2.根據(jù)AQI值判斷城市的空氣質(zhì)量。若城市的AQI值(整數(shù))不超過(guò)100則空氣質(zhì)量?jī)?yōu)良,否則空氣質(zhì)量有污染。當(dāng)輸入的AQI值為-1時(shí)則退出程序。不要更改程序結(jié)構(gòu),將題中的①②③④填入正確的語(yǔ)句。
city=input(“請(qǐng)輸入城市名:”)
AQI=int(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
①______ AQI!=-1:
if ②______:
print(city,“的空氣質(zhì)量?jī)?yōu)良。”)
③______:
print(city,“的空氣質(zhì)量有污染。”)
city=input(“請(qǐng)輸入城市名:”)
AQI=④(input(“請(qǐng)輸入空氣質(zhì)量指數(shù)AQI的值:”))
(1)序號(hào)①答案為
A.if
B.while
C.for
D.def
(2)序號(hào)②答案為
A.AQI>=100
B.AQI<=100
C.AQI>100
D.AQI<100
(3)序號(hào)③答案為
A.elif
B.break
C.if
D.else
(4)序號(hào)④答案為
A.int
B.float
C.str
D.else發(fā)布:2025/1/2 11:0:1組卷:0引用:0難度:0.4 -
3.利用海倫公式求解三角形面積。已知a,b,c為三角形的三條邊長(zhǎng),p為三角形的半周長(zhǎng),即p=(a+b+c)/2,計(jì)算此三角形面積S的海倫公式為:
。不要更改程序結(jié)構(gòu),將題中的①②③填入正確的語(yǔ)句。
import math#導(dǎo)入數(shù)學(xué)模塊
def hl(a,b,c):#定義求三角形面積的函數(shù)
p=①
s=math.jye.ai(②)#sqrt用于計(jì)算算術(shù)平方根
return ③#返回面積的值
a,b,c=3,4,5#邊長(zhǎng)依次賦值
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)序號(hào)②答案為
A.(a+b+c)/2 B.p*(p-a)*(p-b)*(p-c)
C.(a+b+c)*2 D.(3+4+5)/2
(3)序號(hào)③答案為
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