《数据结构》自测题2.docVIP

  • 14
  • 0
  • 约4.86千字
  • 约 5页
  • 2017-08-24 发布于河南
  • 举报
《数据结构》自测题2 一、单选题 从供选择的答案中选出正确的答案,将其编号填入括号中。 1、在数据结构的讨论中把数据结构从逻辑上分为( )。 A: 内部结构与外部结构 B: 静态结构与动态结构 C: 线性结构与非线性结构 D: 紧凑结构与非紧凑结构 2、采用线性链表表示一个向量时,要求占用的存储空间地址( )。 A: 必须是连续的 B 部分地址必须是连续的 C: 一定是不连续的 C: 可连续可不连续 3、采用顺序搜索方法查找长度为n的顺序表时,搜索成功的平均搜索长度为( )。 A: n B: n/2 C: (n-1)/2 D: (n+1)/2 4、在一个单链表中,若q结点是p结点的前驱结点,若在q与p之间插入结点s,则执行( )。 A: s-link = p-link; p-link = s; B: p-link = s; s-link = q; C: p-link = s-link; s-link = p; D: q-link = s; s-link = p; 5、如果想在4092个数据中只需要选择其中最小的5个,采用( )方法最好。 A: 起泡排序 B: 堆排序 C: 锦标赛排序 D: 快速排序 6、设有两个串t和p,求p在t中首次出现的位置的运算叫做( )。 A: 求子串 B: 模式匹配 C: 串替换 D: 串连接 7、在数组A中,每一个数组元素A[i, j] 占用3个存储字,行下标i从1到8,列下标j从1到10。所有数组元素相继存放于一个连续的存储空间中,则存放该数组至少需要的存储字数是( )。 A: 80 B: 100 C: 240 D: 270 8、将一个递归算法改为对应的非递归算法时,通常需要使用( )。 A: 栈 B: 队列 C: 循环队列 D: 优先队列 9、一个队列的进队列顺序是1, 2, 3, 4,则出队列顺序为( )。 A: 4, 3, 2, 1 B: 2, 4, 3, 1 C: 1, 2, 3, 4 D: 3, 2, 1, 4 10、在循环队列中用数组A[0..m-1] 存放队列元素,其队头和队尾指针分别为front和rear,则当前队列中的元素个数是( )。 A: ( front - rear + 1) % m B: ( rear - front + 1) % m C: ( front - rear + m) % m D: ( rear - front + m) % m 二、阅读理解题 给出下列递归过程的执行结果。 (1) void unknown ( int w ) { if ( w ) { unknown ( w-1 ); for ( int i = 1; i = w; i++ ) cout w; cout endl; } } 调用语句为 unknown (4)。 (2) void unknown ( int m ) { cout n % 10 ; if ( int ( n / 10 ) ) unknown ( int ( n / 10 ) ); } 调用语句为unknown ( 582 )。 (3) int unknown ( int m ) { int value; if ( ! m ) value = 3; else value = unknown ( m-1 ) + 5; return value; } 执行语句为 cout unknown (3)。 三、填空题 设单链表结构为: struct ListNode { int data; ListNode *lin

文档评论(0)

1亿VIP精品文档

相关文档