수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • C언어
    • 비주얼베이직
  • 결혼생활
    • 출산/육아
    • 결혼준비
    • 엄마이야기방
  • 일상생활
    • 면접
    • 취업
    • 진로선택
  • 교육
    • 교육일반
    • 아이교육
    • 토익
    • 해외연수
    • 영어
  • 취미생활
    • 음악
    • 자전거
    • 수영
    • 바이크
    • 축구
  • 기타
    • 강아지
    • 제주도여행
    • 국내여행
    • 기타일상
    • 애플
    • 휴대폰관련
  • 프로그램 개발일반
  • C언어
  • 비주얼베이직

2008에서는 실행이 오류가 나는데 visual studio에서는 잘 되는 경우는 어떤 경우인가요?

비치

2023.04.01

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

신청하기





COMMENT

댓글을 입력해주세요. 비속어와 욕설은 삼가해주세요.

번호 제 목 글쓴이 날짜
2698782 기초적인 함수 질문이요ㅠㅠㅠㅠ 내담 2025-06-20
2698749 프로그램 짜던 도중 패닉입니다...ㅜ 파랑 2025-06-19
2698719 조건부컴파일 질문입니다.~ (2) 큐트 2025-06-19
2698693 재귀 함수 에러 바닐라 2025-06-19
2698673 고민이있는데 들어좀주세요!! (1) 초코맛캔디 2025-06-19
2698644 1부터 n까지의 합을 구하는데 엄청긴숫자의 합을 구할때는 어떻게 해야하나요? (4) 슬우 2025-06-18
2698616 다른 함수로 안넘어갑니다..;;; 도1도캣 2025-06-18
2698587 배열하다 막혀서... (3) WhiteCat 2025-06-18
2698559 문자열을 비우는방법 (2) 하늘 2025-06-18
2698528 착하고 친절한 선생씌구해염~ㅋㅋ (4) 옆집언니야 2025-06-17
2698502 자료구조 큐 캔서 2025-06-17
2698477 실행화면 배경문의요 선아 2025-06-17
2698430 변수의 값이 저장이 않되네요;; (4) 피네 2025-06-16
2698404 C#을 배울려고 하는데 C나 C++을 알아야 하나요 ?? (1) 신당 2025-06-16
2698342 프로그램 질문점녀 (4) 데빌의눈물 2025-06-16
2698318 파일 입출력 질문입니다~ (2) 꽃 2025-06-15
2698291 문자 출력 함수 : putchar, fputc에 관하여. 으뜸 2025-06-15
2698261 씨언어 (1) 마리 2025-06-15
2698212 구조체, 포인터가 같이 들어간 프로그램 소스코드 있으신분? (4) 그림자 2025-06-14
2698184 간단한 C언어 인데 .. 붕붕 2025-06-14
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

수다닷컴 | 여러분과 함께하는 수다토크 커뮤니티 수다닷컴에 오신것을 환영합니다.
사업자등록번호 : 117-07-92748 상호 : 진달래여행사 대표자 : 명현재 서울시 강서구 방화동 890번지 푸르지오 107동 306호
copyright 2011 게시글 삭제 및 기타 문의 : clairacademy@naver.com