- 5
- 0
- 约1.96万字
- 约 28页
- 2017-01-04 发布于浙江
- 举报
C/C++面试题10
C语言、C++程序设计面试题集锦
①链表反转
单向链表的反转是一个经常被问到的一个面试题,也是一个非常基础的问题。比如一个链表是这样的: 1-2-3-4-5 通过反转后成为5-4-3-2-1.
最容易想到的方法遍历一遍链表,利用一个辅助指针,存储遍历过程中当前指针指向的下一个元素,然后将当前节点元素的指针反转后,利用已经存储的指针往后面继续遍历。源代码如下:
struct linka {int data;linka* next;};void reverse(linka* head) {if(head ==NULL) return;linka *pre, *cur, *ne;pre=head;cur=head-next;while(cur){ ne = cur-next; cur-next = pre; pre = cur; cur = ne;}head-next = NULL;head = pre;}
还有一种利用递归的方法。这种方法的基本思想是在反转当前节点之前先调用递归函数反转后续节点。源代码如下。不过这个方法有一个缺点,就是在反转后的最后一个结点会形成一个环,所以必须将函数的返回的节点的next域置为NULL.因为要改变head指针,所以我用了引用。算法的源代码如下:
linka* reverse(linka* p,linka* head){if(p == NULL || p-next == NULL){ head=p; return p;}else{ linka* tmp = reverse(p-next,head); tmp-next = p; return p;}}
②已知String类定义如下:
class String{public:String(const char *str = NULL); // 通用构造函数String(const String another); // 拷贝构造函数~ String(); // 析构函数String operater =(const String rhs); // 赋值函数private:char *m_data; // 用于保存字符串};
尝试写出类的成员函数实现。
答案:
String::String(const char *str){if ( str == NULL ) //strlen在参数为NULL时会抛异常才会有这步判断{m_data = new char[1] ;m_data[0] = \0 ;}else{m_data = new char[strlen(str) + 1];strcpy(m_data,str);}
}
String::String(const String another){m_data = new char[strlen(another.m_data) + 1];strcpy(m_data,other.m_data);}
String String::operator =(const String rhs){if ( this == rhs)return *this ;delete []m_data; //删除原来的数据,新开一块内存m_data = new char[strlen(rhs.m_data) + 1];strcpy(m_data,rhs.m_data);return *this ;}
String::~String(){delete []m_data ;}
③网上流传的c++笔试题汇总
1.求下面函数的返回值(微软)
int func(x){int countx = 0;while(x){countx ++;x = x(x-1);}return countx;}
假定x = 9999. 答案:8
思路:将x转化为2进制,看含有的1的个数。
2. 什么是“引用”?申明和使用“引用”要注意哪些问题?
答:引用就是某个目标变量的“别名”(alias),对应用的操作与对变量直接操作效果完全相同。申明一个引用的时候,切记要对其进行初始化。引用声明完毕后,相当于目标变量名有两个名称,即该目标原名称和引用名,不能再把该引用名作为其他变量名的别名。声明一个引用,不是新定义了一个变量,它只表示该引用名是目标变量名的一个别名,它本身不是一种数据类型,因此引用本身不占存储单元,系统也不给引用分
您可能关注的文档
- 2015高压试验试题库【参考】.doc
- 2015公需答案【参考】.doc
- 2015广西生态文明与可持续发展考试及答案【参考】.doc
- 2015国家电网企业文化题库【参考】.doc
- 2015华师作业高起专学员计算机基础作业题及答案【参考】.docx
- 2015监理续期再教育试题及答案房建建筑工程【参考】.doc
- 2015科目一题库1073题最新版【参考】.doc
- 2015洛阳市专业技术人员继续教育部分试题答案【参考】.doc
- 2015年安检机构检验人员考试新题库【参考】.doc
- 2015年电厂燃料运行高级工考试试题和答案【参考】.doc
- GB/T 42818.2-2026认知无障碍 第2部分:报告.pdf
- 中国国家标准 GB/T 47116-2026地下采矿机械 工作面移动式采掘机械 采煤机和犁式系统的安全要求.pdf
- 《GB/T 47116-2026地下采矿机械 工作面移动式采掘机械 采煤机和犁式系统的安全要求》.pdf
- 中国国家标准 GB/T 42818.2-2026认知无障碍 第2部分:报告.pdf
- 《GB/T 42818.2-2026认知无障碍 第2部分:报告》.pdf
- 《GB/T 27664.1-2026无损检测仪器 超声检测设备的性能与检验 第1部分:仪器》.pdf
- 中国国家标准 GB/T 27664.1-2026无损检测仪器 超声检测设备的性能与检验 第1部分:仪器.pdf
- GB/T 27664.1-2026无损检测仪器 超声检测设备的性能与检验 第1部分:仪器.pdf
- GB/T 45305.5-2026声学 建筑构件隔声的实验室测量 第5部分:测试设施和设备的要求.pdf
- 中国国家标准 GB/T 45305.5-2026声学 建筑构件隔声的实验室测量 第5部分:测试设施和设备的要求.pdf
原创力文档

文档评论(0)