在数据库的两张数据表中有各有一批学生的考试成绩,小吴要将两张表中的数据读取并按成绩从高到低排列输出.成绩相同时,第一批学生优先输出.小吴编写了一个VB程序,程序运行时,将相关信息分别读入数组cj和xm的前后两段,单击按钮 Command1 后,在列表框List1中输出运行结果.实现上述功能的 VB 代码如下,但加框处代码有错,请改正:
Dim xm(1to 1000)as string'存储学生姓名
Dim cj(1to 1000)as integer'存储学生成绩
Dim rs1 as integer'第一批学生人数
Dim rs2 as integer'第二批学生人数
Private Sub Form_Load'该处具体代码省略
'第1步:从数据库读取第1批学生的人数rs1,按成绩从高到低的顺序将成绩存入cj(1)、'cj(2)…cj(rs1)中,姓名存入xm(1)、xm(2)…xm(rs1)中
'第2步:从数据库读取第2批学生的人数rs2,按成绩从高到低的顺序将成绩存入'cj(rs1+1)、cj(rs1+2)…cj(rs1+rs2)中,姓名存入xm(rs1+1)、xm(rs1+2)…xm(rs1+rs2)中
End Sub
Private Sub Command1_Click
i=1'i表示第一批中,尚未输出的学生中成绩最高学生的序号
j=rs1+1'j表示第二批中,尚未输出的学生中成绩最高学生的序号
‘以下程序开始按成绩高低逐个输出,每次输出前后两段中,尚未处理的学生中成绩最高的
n=1 |
n=0
n=0
‘(1)Do While i<=rs1And j<=rs1+rs2‘两段都有未输出的情况,输出两段中最大值
n=n+1
If cj(i)>=cj(j) Then
k=i:i=i+1
Else
k=j:j=j+1
End If
List1.AddItem (“第“+Str(n)+“名“+xm(k)+“成绩:“+Str(cj(k)))
Loop
Do While i<=rs1‘剩下第一段还有未输出的,逐个输出
n=n+1
List1.AddItem (“第“+Str(n)+“名“+xm(i)+“成绩:“+Str(cj(i)))
i=i+1
Loop
Do While
j<=rs2 |
j<=rs1+rs2
j<=rs1+rs2
‘(2)若第二段还有未输出的,逐个输出n=n+1
List1.AddItem (“第“+Str(n)+“名“+xm(j)+“成绩:“+Str(cj(j)))
j=j+1
Loop
End Sub.
【考点】对象的属性、方法和事件;编辑事件处理过程的代码.
【答案】n=0;j<=rs1+rs2
【解答】
【点评】
声明:本试题解析著作权属菁优网所有,未经书面同意,不得复制发布。
发布:2024/4/20 14:35:0组卷:8引用:1难度:0.3
相似题
-
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