祝愿大家身体健康!

 站点注册  找回密码
 站点注册

QQ登录

只需一步,快速开始

查看: 7504|回复: 3

C/C++面试题大全 进入名企的敲门砖(连载)

[复制链接]

C/C++面试题大全 进入名企的敲门砖(连载)

[复制链接]
jiameng1987

主题

0

回帖

2

积分

新手上路

积分
2
贡献
在线时间
小时
2009-6-26 10:51:21 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。

您需要 登录 才可以下载或查看,没有账号?站点注册

×
双向链表的查找节点。





考点:双向链表的操作
出现频率:★★★★
解析:
使用right指针遍历,直至找到数据为data的节点,如果找到节点,返回节点,否则返回NULL。
1       //查找节点,成功则返回满足条件的节点指针,否则返回NULL
2         DbNode *FindNode(DbNode *head, int data)   //参数1是链表的表头节点
3         {                                          //参数2是要查找的节点,其数据为data
4                DbNode *pnode = head;
5      
6                if (head == NULL)                     //链表为空时返回NULL
7                {
8                         return NULL;
9                }
10   
11              /*找到数据或者到达链表末尾退出while循环*/
12              while (pnode->right != NULL && pnode->data != data)
13              {
14                       pnode = pnode->right;             //使用right指针遍历
15              }
16   
17              //没有找到数据为data的节点,返回NULL
18              if (pnode->right == NULL)
19              {
20                       return NULL;
21              }
22
23              return pnode;
24     }
共享共进共赢Sharing And Win-win Results
SYBASEBBS - 免责申明1、欢迎访问“SYBASEBBS.COM”,本文内容及相关资源来源于网络,版权归版权方所有!本站原创内容版权归本站所有,请勿转载!
2、本文内容仅代表作者观点,不代表本站立场,作者自负,本站资源仅供学习研究,请勿非法使用,否则后果自负!请下载后24小时内删除!
3、本文内容,包括但不限于源码、文字、图片等,仅供参考。本站不对其安全性,正确性等作出保证。但本站会尽量审核会员发表的内容。
4、如本帖侵犯到任何版权问题,请立即告知本站 ,本站将及时删除并致以最深的歉意!客服邮箱:admin@sybasebbs.com
jiameng1987 楼主

主题

0

回帖

2

积分

新手上路

积分
2
贡献
在线时间
小时
2009-6-26 10:52:07 | 显示全部楼层
解释什么是模板的特化(template specialization)?
考点:模板的特化的理解
出现频率:★★★
解析:
模板的特化(template specialization)分为两类:函数模板的特化和类模板的特化。
(1)函数模板的特化:当函数模板需要对某些类型进行特别处理,称为函数模板的特化。例如:
1       bool IsEqual(T t1, T t2)
2       {
3                return t1 == t2;
4       }
5
6       int main()
7       {
8                char str1[] = "Hello";
9                char str2[] = "Hello";
10              cout << IsEqual(1, 1) << endl;
11              cout << IsEqual(str1, str2) << endl;   //输出0
12              return 0;
13     }
代码11行比较字符串是否相等。由于对于传入的参数是char *类型的,max函数模板只是简单的比较了传入参数的值,即两个指针是否相等,因此这里打印0。显然,这与我们的初衷不符。因此,max函数模板需要对char *类型进行特别处理,即特化:
1         template <>
2       bool IsEqual(char* t1, char* t2)           //函数模板特化
3       {
4                return strcmp(t1, t2) == 0;
5       }
这样,当IsEqual函数的参数类型为char* 时,就会调用IsEqual特化的版本,而不会再由函数模板实例化。
(2)类模板的特化:与函数模板类似,当类模板内需要对某些类型进行特别处理时,使用类模板的特化。例如:
1         template <class T>
2       class compare
3       {
4       public:
5                bool IsEqual(T t1, T t2)
6                {
7                         return t1 == t2;
8                }
9       };
10   
11     int main()
12     {
13              char str1[] = "Hello";
14              char str2[] = "Hello";
15              compare<int> c1;
16              compare<char *> c2;   
17              cout << c1.IsEqual(1, 1) << endl;        //比较两个int类型的参数
18              cout << c2.IsEqual(str1, str2) << endl;   //比较两个char *类型的参数
19              return 0;
20     }
这里代码18行也是调用模板类compare<char*>的IsEqual进行两个字符串比较,显然这里存在的问题和上面函数模板中的一样,我们需要比较两个字符串的内容,而不是仅仅比较两个字符指针。因此,需要使用类模板的特化:
1         template<>
2       class compare<char *> //特化(char*)
3       {
4       public:
5                bool IsEqual(char* t1, char* t2)
6                {
7                         return strcmp(t1, t2) == 0;         //使用strcmp比较字符串
8                }
9       };
注意:进行类模板的特化时,需要特化所有的成员变量及成员函数。
共享共进共赢Sharing And Win-win Results
jiameng1987 楼主

主题

0

回帖

2

积分

新手上路

积分
2
贡献
在线时间
小时
2009-6-30 14:42:30 | 显示全部楼层
双向链表的打印。


更多内容请到“融智技术学苑”(http://www.rzchina.net)了解。



考点:双向链表的操作
出现频率:★★★★
解析:
与测长的方法一样,使用right指针进行遍历。
1       //打印整个链表
2       void PrintList(DbNode *head)             //参数为链表的表头节点
3       {
4                DbNode *pnode = NULL;
5      
6                if (head == NULL)                  //head为NULL表示链表空
7                {
8                         return;
9                }
10              pnode= head;
11              while (pnode != NULL)
12              {
13                       printf("%d ", pnode->data);
14                       pnode = pnode->right;          //使用right指针遍历
15              }
16              printf("\n");
17     }
共享共进共赢Sharing And Win-win Results
jiameng1987 楼主

主题

0

回帖

2

积分

新手上路

积分
2
贡献
在线时间
小时
2009-6-30 14:46:44 | 显示全部楼层
双向链表的打印。


更多内容请到“融智技术学苑”(http://www.rzchina.net)了解。



考点:双向链表的操作
出现频率:★★★★
解析:
与测长的方法一样,使用right指针进行遍历。
1       //打印整个链表
2       void PrintList(DbNode *head)             //参数为链表的表头节点
3       {
4                DbNode *pnode = NULL;
5      
6                if (head == NULL)                  //head为NULL表示链表空
7                {
8                         return;
9                }
10              pnode= head;
11              while (pnode != NULL)
12              {
13                       printf("%d ", pnode->data);
14                       pnode = pnode->right;          //使用right指针遍历
15              }
16              printf("\n");
17     }
共享共进共赢Sharing And Win-win Results
您需要登录后才可以回帖 登录 | 站点注册

本版积分规则

免责声明:
本站所发布的一切破解补丁、注册机和注册信息及软件的解密分析文章仅限用于学习和研究目的;不得将上述内容用于商业或者非法用途,否则,一切后果请用户自负。本站信息来自网络,版权争议与本站无关。您必须在下载后的24个小时之内,从您的电脑中彻底删除上述内容。如果您喜欢该程序,请支持正版软件,购买注册,得到更好的正版服务。如有侵权请邮件与我们联系处理。

Mail To:Admin@SybaseBbs.com

QQ|Archiver|PowerBuilder(PB)BBS社区 ( 鲁ICP备2021027222号-1 )

GMT+8, 2024-11-21 23:26 , Processed in 0.054969 second(s), 10 queries , MemCached On.

Powered by Discuz! X3.5

© 2001-2024 Discuz! Team.

快速回复 返回顶部 返回列表