2013-04-28 47 views
0

我一直致力於在C語言中實現一個二進制搜索樹,用於編程類中的作業分配。在Visual Studio 2010中編寫大量代碼並進行編譯之後,我遇到了許多錯誤。語法執行二叉搜索樹時出錯(C)

我已經在網上尋找那些已經得到類似錯誤的人,他們中的任何一個都不夠近,我不知道問題可能是什麼。

下面是代碼:

/*This code will implement a binary search tree based on 20 
user-inputed integers. It will then implement a search, 
insert, delete, and traverse function. */ 

#include <stdio.h> 
#include <stdlib.h> 
#define ARRSIZE 20 

/*------ TYPE DEFINITIONS ------*/ 

typedef struct node 
{ 
    int data; 
    node* left; 
    node* right; 
}; 

typedef struct tree 
{ 
    int count; 
    node* root; 
}; 

/*------ FUNCTION DECLARTATIONS ------*/ 

void InitializeTree (tree* ptree); 
int insert (int data, tree* ptree); 
void place (node* root, node* new_node); 

/*------ MAIN FUNCTION ------*/ 

int main (void) 
{ 
    int i, check, arr[ARRSIZE]; 
    tree BST; 

    InitializeTree(&BST); 

    printf("Enter 20 integers for a list.\n"); 

    for(i=0; i<ARRSIZE; i++) 
    { 
     printf("Integer %d:\n", i+1); 
     scanf("%d", &arr[i]); 
     check = insert(arr[i], &BST); 
     if(check == 0) 
     { 
      printf("Error in creating node.\n"); 
      exit(1); 
     } 
    } 

    return 0; 
} 

/* 
* 
* ADDITIONAL FUNCTIONS 
* 
*/ 

/*------ CREATION FUNCTIONS ------*/ 

void InitializeTree (tree* ptree) 
{ 
    ptree = (tree*) malloc(sizeof(tree)); 
    ptree->count = 0; 
} 

int insert (int data, tree* ptree) 
{ 
    node* new_node; 

    new_node = (node*) malloc(sizeof(node)); 
    if(new_node == NULL) 
    { 
     printf("Couldn't create a node.\n"); 
     return 0; 
    } 
     new_node->data = data; 

    ptree->count++; 

    if(ptree->root == NULL) 
    { 
     ptree->root = new_node; 
    } 

    else 
    { 
     place(ptree->root, new_node); 
    } 
    return 1; 

} 

void place (node* root, node* new_node) 
{ 
    if(new_node->data < root->data) 
    { 
     if(root->left == NULL) 
     { 
      root->left = new_node; 
     } 
     else 
     { 
      place(root->left, new_node); 
     } 
    } 
    else 
    { 
     if(root->right == NULL) 
     { 
      root->right = new_node; 
     } 
     else 
     { 
     place(root->right, new_node; 
     } 
    } 
} 

的錯誤是這樣的:

1>bin-tree.c(16): error C2061: syntax error : identifier 'node' 
1>bin-tree.c(17): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(18): error C2059: syntax error : '}' 
1>bin-tree.c(23): error C2061: syntax error : identifier 'node' 
1>bin-tree.c(24): error C2059: syntax error : '}' 
1>bin-tree.c(28): error C2143: syntax error : missing ')' before '*' 
1>bin-tree.c(28): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(28): error C2059: syntax error : ')' 
1>bin-tree.c(29): error C2143: syntax error : missing ')' before '*' 
1>bin-tree.c(29): error C2081: 'tree' : name in formal parameter list illegal 
1>bin-tree.c(29): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(29): error C2059: syntax error : ')' 
1>bin-tree.c(30): error C2143: syntax error : missing ')' before '*' 
1>bin-tree.c(30): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(30): error C2143: syntax error : missing ';' before '*' 
1>bin-tree.c(30): error C2059: syntax error : ')' 
1>bin-tree.c(37): error C2065: 'tree' : undeclared identifier 
1>bin-tree.c(37): error C2146: syntax error : missing ';' before identifier 'BST' 
1>bin-tree.c(37): error C2065: 'BST' : undeclared identifier 
1>bin-tree.c(39): warning C4013: 'InitializeTree' undefined; assuming extern returning int 
1>bin-tree.c(39): error C2065: 'BST' : undeclared identifier 
1>bin-tree.c(47): warning C4013: 'insert' undefined; assuming extern returning int 
1>bin-tree.c(47): error C2065: 'BST' : undeclared identifier 
1>bin-tree.c(66): error C2143: syntax error : missing ')' before '*' 
1>bin-tree.c(66): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(66): error C2059: syntax error : ')' 
1>bin-tree.c(67): error C2054: expected '(' to follow 'ptree' 
1>bin-tree.c(72): error C2143: syntax error : missing ')' before '*' 
1>bin-tree.c(72): error C2081: 'tree' : name in formal parameter list illegal 
1>bin-tree.c(72): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(72): error C2059: syntax error : ')' 
1>bin-tree.c(73): error C2054: expected '(' to follow 'ptree' 
1>bin-tree.c(99): error C2143: syntax error : missing ')' before '*' 
1>bin-tree.c(99): error C2143: syntax error : missing '{' before '*' 
1>bin-tree.c(99): error C2143: syntax error : missing ';' before '*' 
1>bin-tree.c(99): error C2059: syntax error : ')' 
1>bin-tree.c(100): error C2054: expected '(' to follow 'new_node' 

有誰知道什麼可能導致這樣的許多錯誤?

typedef struct node 
{ 
    int data; 
    node* left; 
    node* right; 
}; 

typedef struct tree 
{ 
    int count; 
    node* root; 
}; 

到:

回答

4

從改變你的typedef

typedef struct node 
{ 
    int data; 
    struct node* left; // <<< 
    struct node* right; // <<< 
} node;     // <<< 

typedef struct tree 
{ 
    int count; 
    node* root; 
} tree;     // <<< 

也由@Binayaka指出,你有一個失蹤支架 - 改變

place(root->right, new_node; 

到:

place(root->right, new_node); 
+0

我做了,但我仍然得到相同的錯誤。 – Zelmec 2013-04-28 16:13:11

+0

您是否確定*您提出了所有*變更?我會在答案中突出顯示它們... – 2013-04-28 16:13:41

+2

對原始代碼的第118行缺少括號。將它與給定的答案一起更改:) – 2013-04-28 16:14:54