当前位置: 高中信息技术(信息科技) /浙教版 /选修1 算法与程序设计 /第五章 算法实例的程序实现 /5.3 排序算法的程序实现
试卷结构: 课后作业 日常测验 标准考试
| 显示答案解析 | 全部加入试题篮 | 平行组卷 试卷细目表 发布测评 在线自测 试卷分析 收藏试卷 试卷分享
下载试卷 下载答题卡

高中信息技术算法与程序设计 排序算法

更新时间:2022-03-31 浏览次数:53 类型:同步测试
一、选择题
  • 1. 采用冒泡排序算法对数组a中的6个数据“8,20,5,17,30,9”进行排序,部分程序代码如下:

    For i=1 To 2

        For j=6 To i+1 Step -1

        If a(j)>a(j-1) Then

            t=a(j): a(j)=a(j-1): a(j-1)=t

        End If

        Next j

    Next i

    运行该程序,数据交换的次数为(  )

    A . 1 B . C . 3 D . 4
  • 2. 采用冒泡排序对数组d中元素进行排序,第一趟排序后的结果为“10,25,15,30,50,38,60,55”,则d数组中元素的初始顺序不可能是(  )
    A . 25,15,30,50,38,60,55,10 B . 25,15,30,50,38,60,10,55 C . 25,15,10,50,38,60,30,55 D . 25,15,30,50,10,38,60,55
  • 3. 对数组元素b(1)~b(8)进行降序排序,其排序算法的VB部分程序如下:

    For x = 1 To 7

        w = x

        For y = x + 1 To 8

            

        Next y

        If w < > x Then

            Temp = b(x): b(i) = b(w): b(w) = temp

        End If

    Next x

    方框中应填入的语句为(  )

    A . If b(w) > b(y) Then w = y B . If b(w) < b(y) Then w = y C . If b(w) > b(y) Then w = x D . If b(w) < b(y) Then w = x
  • 4. 有如下程序段:

    For i = 1 To 4

        For j = i + 1 To 5

            If a(j) > a(i) Then t = a(j): a(j) = a(i): a(i) = t

        Next j

    Next i

    数组元素a(1)~a(5)的值依次为“15,4,12,7,9”,整个排序过程中,数组中数据比较次数和交换次数分别是(  )

    A . 比较11次,交换3次 B . 比较11次,交换4次 C . 比较10次,交换3次 D . 比较10次,交换4次
  • 5. 如下VB程序段:

    st = “ ”

    For i = 1 To 4

        For j = 1 To 10 - i

            If d(j) < d(j + 1) Then

                temp = d(j): d(j) = d(j + 1): d(j + 1) = temp

            End If

        Next j

        st = Str(d(j)) + st

    Next i

    Text1.Text = st

    数组元素d(1)~d(10)中的数据依次为“21,8,12,16,26,71,65,89,42,36”,程序执行后,在文本框Text1中显示的内容是(  )

    A . 8,12,16,21 B . 42,65,71,89 C . 21,16,12,8 D . 89,71,65,42
  • 6. 有如下VB程序段:

    Private Sub Command1_Click()

        Dim a(1 To 100) As String, x As String, st As String

        Dim i As Integer, j As Integer, n As Integer

        x = Text1.Text

        n = Len(Text1.Text)

        For i = 1 To n

            a(i) = Mid(x, i, 1)

        Next i

        For i = 1 To n - 1

            For j = n To i + 1 Step -1

                 If a(j) > a(j - 1) Then

                    st = a(j): a(j) = a(j - 1): a(j - 1) = st

                End If

            Next j

        Next i

        st = “ ”

        For i = 1 To n

            st = st + a(i)

        Next i

        Label1.Caption = st

    End Sub

    程序运行时,在文本框Text1中输入“Text”(不包含双引号),单击按钮Command1,则在标签Label1上显示的内容为(  )

    A . Tetx B . Txte  C . xtTe D . xteT
二、非选择题
  • 7. 下面是一个采用拉锯式排序法对数组元素按升序进行排序的程序,所谓“拉锯式排序法”是这一遍把最小的元素从下往上移动到最上面的位置,下一遍则是从上往下把最大的元素移动到最下面的位置。 程序运行效果如下图所示。

    Private Sub Command1_Click()

        Dim a(10) As Integer, i As Integer

        Randomize ′产生不同的随机数

        For i = 1 To 10

            a(i) = Int(Rnd * 100) + 1

            Text1.Text = Text1.Text & Str(a(i))

        Next i

        Call Shaker_sort(a())     '调用Shaker_sort

        For i = 1 To 10

            Text2.Text = Text2.Text & Str(a(i))

        Next i

    End Sub

    Private Sub Shaker_sort(k() As Integer)

        Dim i As Integer,c As Integer,d As Integer

        Dim t As Integer

        c = 1

        d = 10

        Do While c<=d

            For i=     '从下往上把最小的元素移到最上面的位置

                If k(i-1)>k(i) Then

                    t = k(i - 1):k(i- 1) = k(i):k(i) = t

                End If

            Next i

            For i = c+1 To d-c    '从上到下把最大的元素移到最下面的位置

                If  Then

                    t = k(i+1):k(i+1) = k(i):k(i) = t

                End If

            Next i

            c = c + 1

            

        Loop 

    End Sub

  • 8. 小李基于冒泡排序算法编写了一个VB程序,功能如下:在文本框Text1中显示排序前的数据,单击“排序”按钮Command1,在文本框Text2中显示剔除重复数据后的升序排序结果。程序运行界面如下图所示。

    实现上述功能的VB程序如下,但加框处代码有错,请改正。

    Const n = 10

    Dim a(1 To n) As Integer

    Private Sub Command1_Click()

        Dim i As Integer, j As Integer, t As Integer,bottom As Integer

        '获取排序前数据依次存储在数组a中,并在文本框Text1中显示。代码略

        bottom = n

        i = 1

        Do While i <= bottom - 1

            For j = bottom To i + 1 Step -1

                If   Then      '①

                    t = a(j): a(j) = a(j - 1): a(j - 1) = t

                ElseIf a(j) = a(j - 1) Then   '相邻两个数据相等,进行剔除处理

                            '②

                    bottom = bottom - 1

                End If

            Next j

            i = i + 1

        Loop

        Text2.Text = “ ”

        For i = 1 To bottom

            Text2.Text = Text2.Text + Str(a(i))

        Next i

    End Sub

    程序中加框①处应改正为

    加框②处应改正为

  • 9. 编写一个VB程序,实现功能为在n个数中寻找第m大的数。程序运行时,自动生成n个三位数随机整数,并显示在列表框List1中,单击“排序”按钮Command1,将数据进行排序,并将排好序的数据显示在列表框List2中,在文本框Text1中输入m,单击“计算”按钮Command2,在文本框Text2中显示第m大的数。程序运行效果如下图所示:

    为实现上述功能的VB程序如下,在程序划线处填入合适的代码。

    Dim d(1 To 20) As Integer

    Const n = 20

    Private Sub Form_Load()

        Dim i As Integer, j As Integer, t As Single

        List1.Clear

        Randomize

        For i = 1 To n

            

            List1.AddItem Str(d(i))

        Next i

    End Sub

    Private Sub Command1_Click()

        Dim i As Integer, j As Integer, t1 As Integer

        For i = 1 To n - 1

            For j =

                If d(j) < d(j - 1) Then

                    t1 = d(j): d(j) = d(j - 1): d(j - 1) = t1

                End If

            Next j

        Next i

        For i = 1 To n

            List2.AddItem Str(d(i))

        Next i

    End Sub

    Private Sub Command2_Click()

        Dim m As Integer

        m = Val(Text1.Text)

        Text2.Text = “第” + Str(m) + “ 大的数为:” +

    End Sub

  • 10. 小王编写了一个数据排序且将重复数删除的VB程序。算法的基本思想:先随机生成20个[1,50]区间内的整数,然后按照数据从低到高进行排序,最后删除重复数(相同的数据只保留一个)。

    程序运行时,单击“生成随机数”按钮Command1,则生成20个[1,50]区间内的整数,存储在数组a中,并显示在文本框Text1中;单击“排序并去重”按钮Command2,则将数组a中数据进行从低到高排序,并将排序结果显示在文本框Text2中,将去重后结果显示在文本框Text3中,在标签Label4中显示共删除的重复数个数,程序运行界面如下图所示。

    实现上述功能的VB程序如下,请回答下列问题:

    1. (1) 若20个随机数分别为:7,18,5,7,7,12,7,1,10,14,17,7,9,7,10,16,5,18,8,18,则去掉的重复数共个。
    2. (2) 请在划线处填入合适的代码。

      Dim a(1 To 20) As Integer

      Const n = 20

      Private Sub Command1_Click()

          Dim i As Integer, s1 As String

          Randomize

          s1 = “ ”

          For i = 1 To n

              a(i) = Int(Rnd * 50 + 1)

              s1 = s1 + Str(a(i))

          Next i

          Text1.Text = s1

      End Sub

      Private Sub Command2_Click()

          Dim i As Integer, j As Integer, p As Integer, tt As Integer

          Dim ans As Integer, s2 As String, s3 As String

          For i = 1 To n - 1

              p = i

              For j = n To i + 1 Step -1

                  If a(j) < a(p) Then p = j

              Next j

              If a(i) < > a(p) Then

                  tt = a(i)

                  a(i) = a(p)

                  a(p) = tt

              End If

          Next i

          s2 = “ ”:s3 = “ ”

          ans = 0

          For i = 1 To n

              s2 = s2 + Str(a(i))

          Next i

          Text2.Text = s2

         

          s3 = Str(a(1))

          For i = 2 To n

          If a(i) < > q Then

              

              q = a(i)

          Else

              

          End If

          Next i

          Text3.Text = s3

          Label4.Caption = Str(ans)

      End Sub

微信扫码预览、分享更方便

试卷信息