在 n 個元素的數組中,小程通過邊分段、邊合并的方法將 n 個數據處理成一個非降序數據段(a(1)≤a(2)≤a(3)≤……),排序的方法如下: (a)從第 1 個元素開始,在數組中依次搜索若干個非降序數據段; (b)將第 1、2 個非降序數據段合并成一個新的非降序數據段,再將第 3、4 個非降序數據段合并成一個新的非降序數據段,依次類推。若非降序數據段個數為奇數,則最后 1 個數據段不處理。 (c)合并后的數據段總數大于 1 個時,重復(a)(b)的操作。 編寫 VB 程序,實現上述合并排序功能。運行程序,在標簽 Label1 顯示原始數據,單擊“合并排序”按鈕 Command1,在列表框 List1 中顯示每次排序后結果。排序過程及程序運行界面如圖 a 所示。請回答下列問題: (1)下列既可作為輸入,也可作為輸出的對象是
B
B
。(單選,填字母:A.Label1/B.Text1/C.List1) (2)為實現上述功能的 VB 程序如下,請在橫線處填入合適代碼。 (3)程序中加框處代碼有錯,請改正。 Const n=10 Dim a(1 to n)As Integer Private Sub Form_Load ( ) '產生 n 個 1-100 之間的隨機數,存放在 a 數組中,并顯示在標簽 Label1 中,代碼略。 End Sub Private Sub Command1_Click ( ) Dim num As Integer'num 表示非降序段數 Dim b(n)As Integer,p1 As Integer,p2 As Integer,t As Integer Dim t1 As Integer,t2 As Integer,i As Integer,j As Integer,k As Integer num=0:p1=1 Do While num<>1 t1=pos(p1) num=num+1
p2=p1+t1
p2=p1+t1
If p2>n Then p1=1 Else t2=pos(p2) num=num+1 i=p1:j=p2:t=1 Do While t<=t1+t2'將兩個非降序段合并 If j>=p2+t2 Or
i<p2 And a(i)<a(j)或i<p2 And a(i)<=a(j)
i<p2 And a(i)<a(j)或i<p2 And a(i)<=a(j)
Then b(t)=a(i):i=i+1 Else b(t)=a(j):j=j+1 End If t=t+1 Loop For k=1 To p1+p2'將合并后的結果存入 a 數組 a(p1+k-1)=b(k) Next k p1= If p1>n Then p1=1:num=0 '將每次的排序結果顯示在列表框 List1 中,代碼略。 End If Loop End Sub Function pos(low As Integer)As Integer'查找從 low 開始連續非降序段長度 Dim i As Integer For i=low To n-1 If a(i)>a(i+1)Then Exit For Next i
1.大部分社交軟件都有好友推薦的功能,當用戶 A 和用戶 B 的共同好友數量超過閾值 p 時,由系統向用戶 A 推薦用戶 B。 編寫 VB 程序,實現好友推薦功能。運行程序,列表框 Listl 中顯示用戶 id 及好友列表,在文本框 Textl 中 輸入推薦目標用戶 id,在文本框 Text2 中輸入閾值 p,點擊“推薦”按鈕,在列表框List2 中顯示用戶之間的關系,在標簽 Label5 中顯示向目標用戶推薦的好友列表。程序運行界面如圖: (1)根據如圖所示數據,若輸入用戶 id 為“3”,輸入閾值為“3”,則推薦好友為: