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
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692114 | 컨텍스트 스위칭하는데 걸리는 시간 측정.. | YourWay | 2025-04-19 |
2692086 | 간접참조 연산자, 증감연산자 질문이용! (2) | 블랙캣 | 2025-04-19 |
2692056 | 주석좀 달아주세요. 몇개적엇는데 몇개만달아주세요. (2) | DevilsTears | 2025-04-19 |
2691978 | 진수 쉽게 이해하는법... (3) | 지지않는 | 2025-04-18 |
2691949 | getchar() 한 문자를 입력받는 함수 질문 | 채꽃 | 2025-04-18 |
2691919 | 배열 정렬 및 합치기 질문입니다. | 사과 | 2025-04-18 |
2691845 | c언어왕초보 질문이 있습니다........ | 루나 | 2025-04-17 |
2691815 | void add(int num); 함수... (4) | 살랑살랑 | 2025-04-17 |
2691756 | 명령 프롬프트 스크롤바가 없어요 | 두메꽃 | 2025-04-16 |
2691725 | 자료구조에 관련해서 질문이 있어 글을 올립니다. | 누리알찬 | 2025-04-16 |
2691697 | if 문에서 구조체 배열에 저장되있던 문자열 검사하는 법 ? (2) | 민트맛사탕 | 2025-04-16 |
2691678 | C언어 함수 질문이요~!!! | 연보라 | 2025-04-15 |
2691650 | 반복문 | 돋가이 | 2025-04-15 |
2691618 | 링크드리스트 개념 질문이예요 (3) | 맨마루 | 2025-04-15 |
2691592 | 동적할당 이용 배열선언 질문입니다.ㅠㅠ (3) | 허리달 | 2025-04-15 |
2691542 | /=의 용도를 알려주세요 ㅠㅠ! (2) | 아라 | 2025-04-14 |
2691510 | sizeof 연산자 질문입니다 (2) | 종달 | 2025-04-14 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |
2691450 | [visual c++ 툴]기초 질문 (3) | 해긴 | 2025-04-13 |
2691393 | UNIX 시스템을 사용하려면 어떤 프로그램이 좋을까요? (5) | 든솔 | 2025-04-13 |