수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • 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

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

번호 제 목 글쓴이 날짜
2700287 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) 아련나래 2025-07-03
2700264 문자와 숫자 동시에 입력??? 글고운 2025-07-03
2700236 txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) 미국녀 2025-07-03
2700211 전위 연산자 (2) 어른처럼 2025-07-02
2700183 C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; 피스케스 2025-07-02
2700150 꼭좀 도와주세요ㅠㅠㅠ 호습다 2025-07-02
2700095 연산문제...질문... 오빤테앵겨 2025-07-01
2700070 while문 , 3의배수 출력하는 프로그램좀 짜주세욤. 횃불 2025-07-01
2700041 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? 헛장사 2025-07-01
2700012 배열// (1) 전갈자리 2025-07-01
2699895 무한루프에 빠집니다.!! 해결좀부탁드려요 (10) 선아 2025-06-30
2699842 질문을 너무 많이 하네여.....죄송.... (2) 해님꽃 2025-06-29
2699816 오류 질문입니다.. (1) 해비치 2025-06-29
2699763 질문입니다 ! 꼭 좀 도와주세요ㅠㅠ (2) 미라 2025-06-28
2699555 c언어 다항식을 입력을 했는데 왜 출력이 안될까요? 피스케스 2025-06-27
2699528 C언어 포인터연산 질문입니다. (3) 안녕나야 2025-06-26
2699476 끌어올림;;달력 짜봤는데요 이 소스 줄일 수 있나요? - 스샷첨부 (2) 클라우드 2025-06-26
2699444 [좀 급함] system("explorer [주소] ") 문에 변수를 사용할 수 있나요? 알 2025-06-26
2699415 파일//read//와 배열 아란 2025-06-25
2699386 구조체 안에 일부분만 char 배열에 복사하려면 어떻게 해야하나요? (1) 미즈 2025-06-25
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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