面试题解(四)之Sony 笔试题

题目:
    下列程序运行时会崩溃,请找出错误并改正,并且说明原因。
  1. #include <stdio.h>
  2. #include <malloc.h>
  3. typedef struct{
  4.     TNode* left;
  5.     TNode* right;
  6.     int value;
  7. } TNode;
  8. TNode* root=NULL;
  9. void append(int N);
  10. int main(){
  11.     append(63);
  12.     append(45);
  13.     append(32);
  14.     append(77);
  15.     append(96);
  16.     append(21);
  17.     append(17); // Again, 数字任意给出
  18. }
  19. void append(int N){
  20.     TNode* NewNode=(TNode *)malloc(sizeof(TNode));
  21.     NewNode->value=N;
  22.     if(root==NULL){
  23.         root=NewNode;
  24.         return;
  25.     }else{
  26.         TNode* temp;
  27.         temp=root;
  28.         while((N>=temp.value && temp.left!=NULL) || (N<temp. value && temp.right!=NULL)){
  29.             while(N>=temp.value && temp.left!=NULL)
  30.                 temp=temp.left;
  31.             while(N<temp.value && temp.right!=NULL)
  32.                 temp=temp.right;
  33.         }
  34.         if(N>=temp.value)
  35.             temp.left=NewNode;
  36.         else
  37.             temp.right=NewNode;
  38.         return;
  39.     }
  40. }
 题解:
  1. #include <stdio.h>
  2. #include <malloc.h>
  3. typedef struct tagNode
  4. {
  5.     struct tagNode *left;
  6.     struct tagNode *right;
  7.     int value;
  8. } TNode;
  9. TNode *root=NULL;
  10. void append(int N);
  11. int main(){
  12.     append(63);
  13.     append(45);
  14.     append(32);
  15.     append(77);
  16.     append(96);
  17.     append(21);
  18.     append(17); // Again, 数字任意给出
  19. }
  20. void append(int N){
  21.     TNode* NewNode=(TNode *)malloc(sizeof(TNode));
  22.     NewNode->value=N;
  23.     if(root==NULL){
  24.         root=NewNode;
  25.         return;
  26.     }else{
  27.         TNode* temp;
  28.         temp=root;
  29.         while((N>temp->value && temp->left!=NULL) || (N<temp->value && temp->right!=NULL)){
  30.             while(N>=temp->value && temp->left!=NULL)
  31.                 temp=temp->left;
  32.             while(N<temp->value && temp->right!=NULL)
  33.                 temp=temp->right;
  34.         }
  35.         if(N>=temp->value)
  36.             temp->left=NewNode;
  37.         else
  38.             temp->right=NewNode;
  39.         return;
  40.     }
  41. }
编译环境: 
        gcc (GCC) 3.2.2 20030222 (Red Hat Linux 3.2.2-5)

运行过程:
[explover@Explover 20081101]$ gcc -g finderr.c -o finderr
[explover@Explover 20081101]$ ./finderr

(本人水平有限,不足之处,请大家多多指正,谢谢!)    
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值