수다닷컴

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

전화번호부 질문이요 ㅜㅜ

뽀그리

2023.04.01

#includestdio.h
#includestdlib.h
#includestring.h#define SIZE 20typedef struct node {
char name[SIZE];
char num[SIZE];
struct node *link;
}NODE;typedef struct HEAD{
int count;
NODE *front;
NODE *last;
NODE *find;
}HEAD;void menu();
void Search_node(HEAD* h,NODE* n);
int isthere_node(HEAD* h,NODE* n);
int Insert_node(HEAD* h,NODE* n);
int Delete_node(HEAD* h,NODE* n);
//////////////////////////////////////////////////////////////////////////////
int main(){
int n_m, n_s, n_i, n_d;
NODE* n = (NODE*)malloc( sizeof(NODE) );
HEAD* h = (HEAD*)malloc( sizeof(HEAD) );
if(h==NULL) exit(1);
if(n==NULL) exit(1);
n-link=NULL;
strcpy(n-name, );
strcpy(n-num, );
h-count = 0; h-front = NULL; h-last = NULL; for(;;) {
menu();
fflush(stdin);
scanf(%d,&n_m); switch(n_m){
case 1:
printf(추가하실 이름을 입려하세요 : );
scanf(%s,n-name);
printf(번호를 입력하세요 : );
fflush(stdin);
scanf(%s,n-num);
n_s = isthere_node(h,n);
if(n_s == 1)
printf(이미 관련된 데이터가 있습니다.\n);
else {
n_i = Insert_node(h,n);
if(n_i == 0) printf(메모리가 다 찼습니다.\n);
else if(n_i==1) printf(등록되었습니다.\n);
//free(n);
}
//system(cls);
break; case 2:
printf(삭제하실 이름 혹은 번호를 입력하세요 : );
scanf(%s,n-name);
//strcpy(n-num, );
n_d = Delete_node(h,n);
if(n_d == 1) printf(삭제되었습니다.\n);
else if(n_d 1) printf(상응하는 데이터가 여러개 있습니다.\n);
else printf(삭제할 데이터가 없습니다.\n);
//free(n);
//system(cls);
break;

case 3://검색
printf(검색하실 이름 혹은 번호를 입력하세요 : );
scanf(%s,n-name);
strcpy(n-num, );
Search_node(h,n);
if(h-find==NULL) printf(관련된 데이터가 없습니다.\n);
else
printf(%s : %s\n,h-find-name,h-find-num);
//free(n);
//system(cls);
break;
case 4:
exit(1);
}
}

}
////////////////////////////////////////////////////////////////////////////////////////////////
void Search_node(HEAD* h,NODE* n) {
//NODE* node = (NODE*)malloc( sizeof(NODE) );
//if(node==NULL) exit(1);
NODE* node = h-front;
h-front = node;
h-find = NULL;

for(;node !=NULL;node = node-link) {
if(strcmp(node-name,n-name) )
h-find = node;
if(strcmp(node-num,n-name) )
h-find = node;
}
}int Delete_node(HEAD* h,NODE* n){
int i = 0;
NODE* node = h-front;
NODE* PREnode = (NODE*)malloc(sizeof(NODE));
PREnode-link = node; for(;node !=NULL;node = node-link) {
if(strcmp(node-name,n-name)==0) {
i++;
PREnode-link = node-link;
free(node);
}
if(strcmp(node-num,n-name)==0) {
i++;
PREnode-link = node-link;
free(node);
}
}
if(i==1) {
h-count--;
return 1;
}
else if(i==0) return 0;
else return 2;
}int Insert_node(HEAD* h,NODE* n) {
NODE* node = (NODE*)malloc( sizeof(NODE) );
if(node==NULL) return 0;

if(h-front == NULL) {
h-front = node;
h-last = node;
}

else (h-last)-link = node;

node-link = NULL;
strcpy(node-name,n-name);
strcpy(node-num,n-num);
h-count++;
return 1;
}

int isthere_node(HEAD* h,NODE* n){
int i=0;
NODE* node = h-front;
for(;node !=NULL;node = node-link) {
if(strcmp(node-name,n-name) ==0 )
i++;
if(strcmp(node-num,n-num)==0)
i++;
}
if(i==0)return 0;
else return 1;
}void menu() {
printf(\t1. 추가\n);
009e25 printf(\t2. 삭제\n);
printf(\t3. 검색\n);
printf(\t4. 종료\n);
printf(선택하세요 : );
}삭제하는 부분에서 에러가나네요 ㅠㅠ..
PREnode를 어떻게 잡아줘야 할지 정확히 잘 모르겠어요.
메인에서 PREnode를 잡고 인자로 날려줘야하는지
아님 함수안에서 저렇게 설정해줘도 되는지....그리고 제가 아직 초보라 보시구 수정 보완해야될점 있으시면 말씀해주세요 ㅠㅠ

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
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
2699361 연결리스트 정렬하는 부분에 대해서 질문 드립니다 아이처럼 2025-06-25
2699304 [기초]아직 안주무시는분 계신가요..?포인터배열? 좀 도와주세요. 놀리기 2025-06-24
2699272 printf() 함수이용해서 프로그램 만들기 질문요! (5) 다가 2025-06-24
2699221 PUSH와 POP코드를 더 간단하게 어떻게 해야할까요? 파라미 2025-06-24
2699192 설치오류가 자꾸 나요 한번봐주세여~ (1) 소녀틳향기 2025-06-23
2699161 for loop안에 있는 if문 (9) Orange 2025-06-23
2699105 링크더리스트 이전 링크값 출력함수. 꼬꼬마 2025-06-23
2699078 정수를 한자리씩 배열에 담는 법은 어떻게 하나요.. (4) 귀염포텐 2025-06-22
2699024 C언어 공부하려는데 도와주세요!!! (2) 달님 2025-06-22
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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