동적할당을 받아 연결리스트로 학생성적을 관리하는 프로그램인데요;
큰돌찬
1 #includestdio.h
2 #includestdlib.h
3 #includestring.h
4
5 struct student{
6 char name[15];
7 int eng;
8 int math;
9 struct student *next;
10 };
11
12 struct student *root=0;
13
14 void add(char *pname, int *e, int *m){
15 struct student *p, *pnew;
16
17 p=root;
18 while(p-next)
19 p=p-next;
20
21 pnew=(struct student*)malloc(sizeof(struct student));
22 strcpy(pnew-name, pname);
23 pnew-eng=*e;
24 pnew-math=*m;
25 pnew-next=NULL;
26 p-next=pnew;
27 }
28
29 int input(char *pname, int *e, int *m){
30 printf(\n이름 : );
31 scanf(%s, pname);
32 printf(영어 : );
33 scanf(%d, e);
34 printf(수학 : );
35 scanf(%d, m);
36 }
37 void del(){
38 struct student *p ,*temp;
39 temp=(struct student*)malloc(sizeof(struct student));
40 char dname[15];
41 printf(삭제할 이름 입력 : );
42 scanf(%s, dname);
43 p=start;
44 p=p-next;
45 while(p!=0){
46 if(strcmp(p-name, dname)==0){
47 temp=p;
48 p=p-next;
49 free(temp);
50 printf(%s : 같은이름발견, dname);
51 }
52 else{
53 printf(같은 이름이 없습니다.\n);
54 return;
55 }
56 p=p-next;
57 }
58 }
59 void display(){
60 struct student *p;
61 p=root;
62 p=p-next;
63 while(p!=0){
64 printf(\n이름: %s 영어: %d 수학: %d 평균: %d, p-name, p-eng, p-math, (p-eng+p-math)/2);
65&nbsbsp; p=p-next;
66 }
67 printf(\n);
68 }
69
70 main(){
71 int menu,eng,math;
72 char name[15];
73 int aver;
74
75 root=(struct student*)malloc(sizeof(struct student));
76 strcpy(root-name, ROOT);
77 root-eng=0;
78 root-math=0;
79 root-next=NULL;
80
81 while(1){
82 printf(\n);
83 printf(--------------\n);
84 printf(- 1. 삽입 -\n);
85 printf(- 2. 삭제 -\n);
86 printf(- 3. 출력 -\n);
87 printf(- 4. 종료 -\n);
88 printf(--------------\n);
89 printf(선택 : );
90 scanf(%d, &menu);
91
92 if(menu==1){ // 삽입메뉴
93 input(name, &eng, &math);
94 add(name, &eng, &math);
95 }
96 else if(menu==2){ //삭제 메뉴
97 del();
98 }
99 else if(menu==3){ //출력 메뉴
100 display();
101 }
102 else if(menu==4){ // 종료 메뉴
103 printf(\n종료합니다.\n\n);
104 break;
105 }
106 else{
107 printf(\n종료합니다.\n\n);
108 break;
109 }
110 }
111 return 0;
112 }
3번 삭제메뉴에서 삭제할이름을 입력하면
이름: 영어: 100 수학: 100 평균: 100
이름: wo 영어: 100 수학: 100 평균: 100이런식으로 이름만 지워집니다.
어디가 잘못된건가요;
-
은별
기존 코드를 보시면 p를 메모리를 해제합니다. ( temp로 복사한다음 메모리 해제하죠 )
그럼 그 앞에 노드가 p를 가리키 때문에 잘못된 메모리 참조하지요.
저는 디버그 모드로 해서 바로 오류가 나던데 아마 릴리즈모드 실행하신게 아닌가 생각이 드네요. -
라이브라
음.. 잘돌아가네요 ^^ 감사합니다..
그런데 죄송하지만.. .. 무엇때문에 이름만 삭제 되고 나머지 기록은 남아있었던것인지
설명해주실수는 없나요.? -
알프레드
아 컴파일러가 잠시 미쳐서요...ㅎㅎ
테스트 해보니 몇군데 수정만 하면 잘 돌아가네요...
void del(){
struct student *p ,*temp, *before;
// temp=(struct student*)malloc(sizeof(struct student));
char dname[15];
printf(\삭제할 이름 입력 : \);
scanf(\%s\ -
갈매빛
p=p-next;
이부분이 잘못 된것 같은데요.. 여기서 p가 아니고 p의 앞노드의 next에 p -next를 대입해야되요.
글구 위에 temp에 동적할당은 왜 하신거지...
컴파일 안되서 정확하게 확인은 안되네요...
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2692230 | 하노이탑 질문입니다. (1) | 미쁘다 | 2025-04-21 |
2692210 | 정보 올림피아드 문제인데.. 풀이 과정이 궁금합니다.(재귀함수) (5) | 물티슈 | 2025-04-20 |
2692144 | C언어와 리눅스에 대한 질문입니다. | 싴흐한세여니 | 2025-04-20 |
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 |