效实中学的同学静校时间经常要被叫去过关,今天又有��个同学要去过关啦~但 这些同学很不幸,他们必须先过�老师的关,再过�老师的关,才能完成过关任务。现在知道每个人过�、�关的时间,比如第��个人,过关的时间分别为�,�.求一 个过关顺序使得过关时间总用时最短,就是让�、�老师的总空闲时间最短。很明显第一个同学在�老师处过关时,�老师必须等待,最后一个同学在�老师处过 关时,�老师也在等待。因此将在�处过关最短的放在最前面,将在�处过关最短的
放在最后面
假设�是�,�中较小的那一个,例如�=3时,过关时间如表:
编号 | 1 | 2 | 3 | ||||||
A | 22 | 3 | 19 | 排序后 | 编号 | 2 | 1 | 3 | |
B | 10 | 17 | 15 | M | 3 | 10 | 15 | ||
M | 10 | 3 | 15 |
则最优的过关顺序为(同学 2,同学 3,同学 1),计算最短时间=3+19+22+10=54,计算时请注意,在过程中若�老师的过关时长较长,会增加�老师的过关时长,最后还需要加上�老师过关的最后一个同学的过关时长。
实现上述功能的 VB 程序如下:
Private Sub Command1_Click( )
Dim a(1 To 100)As Integer,b(1 To 100)As Integer
Dim m(1 To 100)As Integer,s(1 To 100)As Integer
Dim ans(1 To 100)As Integer,n As Integer,tmp As Integer
Dim k As Integer,i As Integer,j As Integer,t As Integer
'输入略,将同学在 A 老师处的过关时间存在 a 数组,在 B 老师处的时间存在 b 数组
n=5
For i=1 To n
If a(i)>b(i) Then m(i)=b(i) Else m(i)=a(i)
s(i)=i
Next i
For i=1 To n-1
For j=i+1 To n
If ① Then
tmp=m(i):m(i)=m(j):m(j)=tmp tmp=s(i):s(i)=s(j):s(j)=tmp
End If
Next j
Next i
k=0:t=n+1
For i=1 To n
If ② Then k=k+1
ans(k)=s(i)
Else
t=t-1 ans(t)=s(i)
End If
Next i
k=0:t=0
For i=1 To n
k=k+a(ans(i))
If ③ Then t=k t=t+b(ans(i))
Next i Print t End Sub
请回答下列问题:
(1)若在 A 老师处过关的 5 个同学的时间分别是:3 5 8 7 10,在 B 老师处过关的 是 6 2 1 4 9,那么,最终过关的总时间是 ?
(2)补充①、②、③处代码实现上述功能。
【考点】编辑事件处理过程的代码.
【答案】;;;
【解答】
【点评】
声明:本试题解析著作权属菁优网所有,未经书面同意,不得复制发布。
发布:2024/4/20 14:35:0组卷:0引用:1难度:0.9
相似题
-
1.根据AQI值判断城市的空气质量。若城市的AQI值(整数)不超过100则空气质量优良,否则空气质量有污染。当输入的AQI值为-1时则退出程序。不要更改程序结构,将题中的①②③④填入正确的语句。
city=input(“请输入城市名:”)
AQI=int(input(“请输入空气质量指数AQI的值:”))
①______ AQI!=-1:
if ②______:
print(city,“的空气质量优良。”)
③______:
print(city,“的空气质量有污染。”)
city=input(“请输入城市名:”)
AQI=④(input(“请输入空气质量指数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发布:2025/1/2 11:0:1组卷:0引用:0难度:0.4 -
2.一球从100米高度自由落下,每次落地后反跳回原高度的一半,再下落。编写一个C程序,求它在第10次落地时,其经过了多少米?第10次反弹多高?
发布:2025/1/2 11:0:1组卷:0引用:3难度:0.3 -
3.利用海伦公式求解三角形面积。已知a,b,c为三角形的三条边长,p为三角形的半周长,即p=(a+b+c)/2,计算此三角形面积S的海伦公式为:
。不要更改程序结构,将题中的①②③填入正确的语句。
import math#导入数学模块
def hl(a,b,c):#定义求三角形面积的函数
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发布:2025/1/2 11:0:1组卷:0引用:0难度:0.4