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;
};
到:
我做了,但我仍然得到相同的錯誤。 – Zelmec 2013-04-28 16:13:11
您是否確定*您提出了所有*變更?我會在答案中突出顯示它們... – 2013-04-28 16:13:41
對原始代碼的第118行缺少括號。將它與給定的答案一起更改:) – 2013-04-28 16:14:54