2008에서는 실행이 오류가 나는데 visual studio에서는 잘 되는 경우는 어떤 경우인가요?
비치
2008에서는 실행이 오류가 나는데 visual studio에서는 잘 되는 경우는 어떤 경우인가요?
아래의 소스를 2008에서 실행을 하면 첫번째 정보만 받아들이고 2번째 부터는 오류를 발생합니다.
반면에 비쥬얼 스튜디오에서는 실행이 잘 됩니다.
혹시 두 컴파일러에서 무슨 차이점이라도 잇나요?(소스 수정해달라는 말 아닙니다^^;)
///////////////////////////////////////////////////////////////////////////////
#include stdio.h
#include string.h
#include stdlib.h
#define MAX 10 //입력받을 이름의 최대 값
#define NAME_SIZE 20 //입력받을 이름의 최대 값
typedef struct _student
{
int id;
char name[MAX];
int grade;
}student; //학생의 정보를 저장할 구조체
typedef struct _node
{
student *value;
struct _node *left;
struct _node *right;
}node; //학생의 정보를 트리로 변화할 구조체
node *head; //스택의 처음과 끝을 표시
void init_head(void);
//부모 노드를 반환!
node* MakeTree(node *imsi);
student *MakeStudent();
node *MakeNode();
void ShoWMenu(void);
node* FindId(int imsi_id);
node *DeleteNode(node *delNode);
void print_all(node *);
int main()
{
init_head();
ShoWMenu();
return 0;
}//main
void print_all(node *imsi)
{
if(imsi)
{
print_all(imsi-left);
puts(Student Information List);
printf(ID: %d Name: %s, Grade:%d\n, imsi-value-id, imsi-value-name, imsi-value-grade);
print_all(imsi-right);
}
}//print_all
void init_head(void)
{
head = (node*)malloc(sizeof(node));
head-value = NULL;
head-left = NULL;
head-right = NULL;
}//init_head //초기화 작업
student *MakeStudent()
{
int imsi_id;
int imsi_grade;
char imsi_name[NAME_SIZE];
student *imsi_student;
node* imsi_node;
//정보를 입력을 받음
printf(Input Id: );
scanf(%d, &imsi_id);
//중복된 Id가 있는지 검사를 수행
//imsi_node = (node*)malloc(sizeof(node));
imsi_node = FindId(imsi_id);
if(imsi_node != NULL) //존재하는 값이 있다면
{
printf(ID %d는 이미 존재합니다!\n, imsi_id);
return NULL;
}
//fflush(stdin)
printf(Input Name: );
scanf(%s, imsi_name);
//fflush(stdin)
printf(Input Grade: );
scanf(%d, &imsi_grade);
//fflush(stdin)
imsi_student = (student*)malloc(sizeof(student));
if(imsi_student == NULL)
{
printf(Student 메모리 할당실패\n);
return NULL;
}
imsi_student-grade = imsi_grade;
imsi_student-id = imsi_id;
strcpy(imsi_student-name, imsi_name);
//free(imsi_node);
return imsi_student;
}//MakeStudent
node *MakeNode()
{
node *imsi_node;
student *imsi_student;
imsi_student = (student*)malloc(sizeof(student));
imsi_student = MakeStudent();
//리턴받은 student 값이 NULL이라면
if(imsi_student == NULL) return NULL;
imsi_node = (node*)malloc(sizeof(imsi_node));
if(imsi_node == NULL)
{
puts(Fail allowing memory to Node);
return NULL;
}
imsi_node-value = imsi_student;
imsi_node-left = NULL;
imsi_node-right = NULL;
return imsi_node;
}//MakeNode
void ShoWMenu(void)
{
int option;
node *imsi_node;
int imsi_id;
puts(1. Input 2.Find 3.Delete 4.Show Data 5.End);
printf(Input option: );
scanf(%d, &option);
while (1)
{
if(option == 1)
{
imsi_node = (node*)malloc(sizeof(node));
if(imsi_node == NULL)
{
puts(Error durgin imsi_nod);
}
else
{
imsi_node = MakeNode();
if(imsi_node == NULL)
{
puts(Fail to make node);
}
else
MakeTree(imsi_node);
}
}//input
else if(option == 2)
{
printf(Input Id: );
scanf(%d, &imsi_id);
imsi_node = FindId(imsi_id);
if(imsi_node == NULL)
{
puts(찾고자 하는 정보가 없습니다);
}
else
{
printf(Information\n);
printf(Id : %d, Name: %s, Grade: %d\n, imsi_node-value-id,imsi_node-value-name, imsi_node-value-grade );
}//찾고자 하는 정보가 있을 경우
}//else find
else if(option == 3)
{
}//delete
else if(option == 4)
{
if(head-left == NULL)
{
puts(There is nothing student information list);
puts();
}
else
print_all(head-left);
puts();
}//show data
else if(option == 5)
{
puts(End);
break;
}
else
{
puts(잘못 입력 하셧습니다);
}
//fflush(stdin)
puts();
puts(1. Input 2.Find 3.Delete 4.Show Data 5.End);
printf(Input option: );
scanf(%d, &option);
//fflush(stdin)
}//while
}//showMenu
node* MakeTree(node *imsi)
{
node *parent;
node *child;
//int differName;
parent = head;
child = head-left;
while (child != NULL)
{
parent = child;
if( (child-value-id) (imsi-value-id) )
child = child-left;
else
Rchild = child-right;
}//while
if( parent == head || ( (imsi-value-id) ( parent-value-id) ))
{
parent-left = imsi;
}
else
parent-right = imsi;
return parent;
}//MakeTree
node* FindId(int imsi_id)
{
node *imsi;
imsi = (node*)malloc(sizeof(node));
imsi = head-left;
while (imsi)
{
if(imsi-value-id == imsi_id) return imsi;
else if(imsi-value-id imsi_id) imsi = imsi-left;
else imsi = imsi-right;
}//while
return NULL;
}//FindId
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |
2675249 | C책 좀 추천해 주세요 (2) | 딸기우유 | 2024-11-16 |
2675193 | 연습문제 17-1 질문입니다. | 한별나라 | 2024-11-15 |
2675172 | 소스점 | 아이뻐 | 2024-11-15 |
2675146 | 단순 연결 리스트인데 출력결과가 이상하게 나와요. | 찬늘봄 | 2024-11-15 |