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
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2694069 | unsigned 질문입니다. | 힘차 | 2025-05-07 |
2694012 | 전공 비전공자 개발자 (10) | 말글 | 2025-05-07 |
2693984 | 오버로딩이 무엇인가요? (2) | 헛매질 | 2025-05-07 |
2693956 | PlaySound재생이 안됩니다!(C에 음악넣기) | 지존 | 2025-05-06 |
2693928 | &와 *의 사용에 관한 명확한 이해 | 제나 | 2025-05-06 |
2693903 | 반복문 설명좀요 ㅠㅠ (2) | 란새 | 2025-05-06 |
2693869 | stdio.h 는 왜 쓰는건가요? (1) | 큰꽃들 | 2025-05-06 |
2693842 | 포인터 변수의 주소값끼리 더하는 것에 대해서 질문드립니다. (1) | 진솔 | 2025-05-05 |
2693811 | 소수 출력;;;; | 화이트캣 | 2025-05-05 |
2693788 | 이런 함수는 없나요? (3) | 앤드류 | 2025-05-05 |
2693758 | txt파일 불러와서 행렬로 저장 | 큰애 | 2025-05-05 |
2693727 | scanf 오류 문제!! (2) | 큰나래 | 2025-05-04 |
2693704 | 구조체 주소록 문제인데 도와주세요 (2) | 도1도캣 | 2025-05-04 |
2693676 | 열혈강의 c언어 질문입니다 | 하양이 | 2025-05-04 |
2693647 | 12.620000 을요 12.620 으로 어떻게 표현해요? (2) | 파도 | 2025-05-04 |
2693619 | 타이틀 코드.. | 단순드립 | 2025-05-03 |
2693591 | 컴파일 에러에서 질문드립니다 (3) | 게자리 | 2025-05-03 |
2693463 | 동적할당 이용시 fwrite사용을 어떻게 해야하나요..? (10) | 일본어못해요 | 2025-05-02 |
2693387 | 배열문제입니다 수정오류캡쳐했습니다 (6) | 연하얀 | 2025-05-01 |
2693356 | text 입출력 내림차순 질문입니다 ㅠ | 빛글 | 2025-05-01 |