【加試題】由數(shù)組a生成數(shù)組b的方法描述如下:
1)將數(shù)組a中的n個元素依次分割出若干個數(shù)據(jù)塊,每個數(shù)據(jù)塊有m×m個元素,m最大值為8,最小值為2.分割時,按盡可能大的數(shù)據(jù)塊進行分割;
2)對每個分割出的數(shù)據(jù)塊用“方陣轉(zhuǎn)換法”進行轉(zhuǎn)換,每次轉(zhuǎn)換后得到的數(shù)據(jù)塊依次存儲在數(shù)據(jù)b中;
3)數(shù)組a分割后的剩余元素(個數(shù)小于4),直接依序存儲到數(shù)組b中。
例如n=140時,可依次分割出3個數(shù)據(jù)塊,元素的個數(shù)分別為64(8×8)、64(8×8)、9(3×3),剩余元素為3個。
“方陣轉(zhuǎn)換法”過程如下:將數(shù)據(jù)塊中m×m個元素按行序排列成一個數(shù)字方陣,從該數(shù)字方陣中按列序得到轉(zhuǎn)換后元素的次序。以3×3數(shù)據(jù)塊為例,轉(zhuǎn)換過程如圖所示:
小明依據(jù)上述描述設(shè)計了如下VB程序。請回答下列問題:
(1)當n=120時,分割出的第3個數(shù)據(jù)塊元素個數(shù)為 44。
(2)請在橫線處填入合適的代碼。
Const n=120
Dim a(1To n) As Integer
Dim b(1To n) As Integer
Private Sub Command1_Click ( )
Dim m As Integer,i As Integer
Dim Start As Integer'當前未分割數(shù)據(jù)的第1個元素下標
Dim Left As Integer'當前未分割數(shù)據(jù)的個數(shù)
Dim pa As Integer'數(shù)組a的下標
Dim pb As Integer'數(shù)組b的下標
'讀取n個轉(zhuǎn)換前的數(shù)據(jù),依次存儲到a(1)、a(2)、…a(n)中,代碼略
m=8
Start=1
Left=n
Do While Left>3
If Left<m*m Then
m=m-1m-1
Else
pa=Start
pb=Start
For i=1To m*m
b(pb)=a(pa)
pb=pb+1
If i Mod m=0Then
pa=start+i/mpa=start+i/m
Else
pa=pa+m
End If
Next i
left=left-m*mleft=left-m*m
Start=Start+m*m
End If
Loop
For i=Start To n
b(i)=a(i)
Next i
'依次輸出轉(zhuǎn)換后數(shù)據(jù)b(1)、b(2)、…b(n)中,代碼略
End Sub。
【考點】編輯事件處理過程的代碼.
【答案】4;m-1;pa=start+i/m;left=left-m*m
【解答】
【點評】
聲明:本試題解析著作權(quán)屬菁優(yōu)網(wǎng)所有,未經(jīng)書面同意,不得復(fù)制發(fā)布。
發(fā)布:2024/4/20 14:35:0組卷:6引用:2難度:0.1
相似題
-
1.學(xué)校舉辦了“語文作文現(xiàn)場賽”,參賽同學(xué)成績存儲在文本文件“gra.jye.ai”中,如左圖所示(每一行記錄一位同學(xué)的姓名和成績,以“:”分隔)。陳老師利用Python程序?qū)ψ魑某煽冞M行處理,統(tǒng)計出各個分數(shù)等級的人數(shù),并輸出結(jié)果。程序運行界面如右圖所示。
實現(xiàn)上述功能的Python程序如下,請在劃線處填入合適的代碼。發(fā)布:2024/12/17 2:0:1組卷:6引用:2難度:0.3 -
2.有如下Python程序段:
執(zhí)行該程序段,輸入字符串“abcdefg”,則輸出的結(jié)果是( ?。?/h2>發(fā)布:2024/12/20 6:30:1組卷:2引用:3難度:0.4 -
3.試題描述的內(nèi)容:
一個單窗體VB程序的運行界面如圖所示。下列說法正確的是( ?。?br />(1)窗體內(nèi)有1個按鈕
(2)窗體內(nèi)有2個文本框
(3)窗體內(nèi)有3個標簽
(4)該窗體的標題(Caption)屬性值是“加法計算器”發(fā)布:2024/12/20 20:0:2組卷:1引用:1難度:0.6
把好題分享給你的好友吧~~