동적할당을 받아 연결리스트로 학생성적을 관리하는 프로그램인데요;
큰돌찬
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에 동적할당은 왜 하신거지...
컴파일 안되서 정확하게 확인은 안되네요...
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2676152 | 기본적인거 하나 질문드립니다. | 개미 | 2024-11-24 |
2676124 | 함수선언관련 질문이에요~...털썩..수정완료 (2) | 가지 | 2024-11-24 |
2676092 | C언어 책 (2) | 아서 | 2024-11-24 |
2676065 | 웹사이트 또는 메신저 등에서 원하는 텍스트를 검사하는방법?? (1) | 모든 | 2024-11-23 |
2676033 | 배열 기초연습중 발생하는 에러 ㅠㅜ... | Creative | 2024-11-23 |
2676005 | keybd_event 게임 제어 | 영글 | 2024-11-23 |
2675900 | 진짜기본적인질문 | 글길 | 2024-11-22 |
2675845 | 수정좀해주세요ㅠㅠㅠ | 해골 | 2024-11-21 |
2675797 | 병합 정렬 소스 코드 질문입니다. (2) | 도래솔 | 2024-11-21 |
2675771 | 큐의 활용이 정확히 어떻게 되죠?? | 해긴 | 2024-11-21 |
2675745 | 도서관리 프로그램 질문이요 | 도리도리 | 2024-11-20 |
2675717 | 2진수로 변환하는것! (3) | 동생몬 | 2024-11-20 |
2675599 | for문 짝수 출력하는 법 (5) | 널위해 | 2024-11-19 |
2675575 | Linux 게시판이 없어서.. | 첫삥 | 2024-11-19 |
2675545 | 구조체 이용할 때 함수에 자료 넘겨주는 것은 어떻게 해야 하나요? | 아연 | 2024-11-19 |
2675518 | 사각형 가로로 어떻게 반복해서 만드는지좀.. 내용 | 신당 | 2024-11-18 |
2675491 | !느낌표를 입력하는것은 어떻게합니까~~?ㅠㅠ (5) | 사지타리우스 | 2024-11-18 |
2675411 | 파일입출력으로 받아온 파일의 중복문자열을 제거한 뒤 파일출력 | 앨버트 | 2024-11-17 |
2675385 | 링크드리스트 주소록 질문드립니다. (1) | 겨루 | 2024-11-17 |
2675356 | 2진수를 10진수로 바꾸려고 하는데 막히네요.. | 풀잎 | 2024-11-17 |