C++链表,队列,栈的几道题目
2012-03-08 22:18
225 查看
1、已知n个人(以编号1,2,3,...,n分别表示)围坐在一张圆桌周围,从编号为k的人开始报数,数到m的那个人出列,他的下一个人又从k开始报数,数到m的那个人出列,依次重复下去,直到圆桌的人全部出列。试用C++编写实现。
解析:本题就是约瑟夫环问题的实际场景,要通过输入n、m、k三个正整数,求出列的序列。这个问题采用的是典型的循环链表的数据结构,就是将一个链表的尾元素指针指向队首元素:p->link=head;
解决问题的核心步骤如下:
(1)建立一个具有n个链节点、无头节点的循环链表。
(2)确定第一个报数人的位置。
(3)不断的从链表中删除链节点,直到链表为空。
答案:
?
2、编程实现队列的入队/出队操作。
答案:?
3、用两个栈实现一个队列的功能,请用C++实现。
解析:思路如下:假设两个栈A和B,且都为空。
可以认为栈A提供入队列的功能,栈B提供出队列的功能。
入队列:入栈A。
出队列:
(1)如果栈B不为空,直接弹出栈B的数据。
(2)如果栈B为空,则依次弹出栈A的数据,放入栈B中,再弹出栈B的数据。
答案:
?
4、请讲诉heap和stack的差别。
解析:在进行C/C++编程时,需要程序员对内存的了解比较精准。经常需要操作的内存可分为以下几个类别:(1)栈区(stack):由编译器自动分配和释放,存放函数的参数值、局部变量的值等。其操作方式类似于数据结构中的栈。
(2)堆区(heap):一般由程序员分配和释放,若程序员不释放,程序结束时可能由操作系统回收。注意它与数据结构中的堆是两回事,分配方式倒是类似于链表
(3)全局区(静态区)(static):全局变量和静态变量的存储是放在一块的,初始化的全局变量和静态变量在一块区域,未初始化的全局变量和静态变量在相邻的另一块区域。程序结束后由系统释放。
(4)文字常量区:常量字符串就是放在这里的,程序结束后由系统释放。
(5)程序代码区:存放函数体的二进制代码。
答案:
(1)stack的空间由操作系统自动分配/释放,heap上的空间手动分配/释放。
(2)stack空间有限,heap是很大的自由存储区。
(3)C中的malloc函数分配内存空间即在堆上,C++中对应的是new操作符。
(4)程序在编译期对变量和函数分配内存都在栈上进行,且程序运行过程中函数调用时参数的传递也在栈上进行。
相关文章推荐
- 几道链表的题目
- 【编程题目】反转链表(C++实现)
- C++ 数组、链表、栈、队列
- C++中采用链表实现队列
- 【编程题目】合并两个排序链表(C++实现)
- C++面试笔记--循环链表,队列,栈,堆
- C++实现链表队列
- c++基本数据结构的类的用法--栈,队列,链表
- 队列 - 以带头结点的循环链表表示队列(C++)
- 程序:找出两个链表的第一个公共节点及c++中堆栈、队列的基本操作
- 几种简单的数据结构的C++实现,树,图,链表,环形队列,栈等---环形队列篇
- LeetCode中几道链表反转相关题目(Reorder List、Rotate List、Reverse Nodes in k-Group)
- 利用 C++ 单向链表实现队列
- c++链表实现队列,深搜加宽搜,加模版类实现迷宫问题;
- c++链表的实现及栈队列
- c++ 链表实现队列
- C++建立队列_利用链表
- C++实现队列(链表版)
- 算法学习记录十二(C++)--->链表题目集合
- 关于C++队列操作(并附上一道Boring题目)