수다닷컴

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

연결리스트 자꾸 오류떠요ㅠㅠ

마루

2023.04.01

질문 제목 : 현재링크랑 서치까지 햇는데자꾸 오류뜨네요...문제가 무엇입니까...이니설라이저상수가 아니라는데 ㅠㅠ 잘모르겟습니다질문 내용 : #include stdio.h
#include windows.h
typedef struct point
{
char name[20];
int hp;
int mp;
double dm;
double ds;
struct point* next;
} node;
void link ( node * dic , int );
void search ( node * dic , char* );
void insert ( node * dic , char* );
void printall ( node * dic );
void findmaxhealth ( node * dic );
void delete ( node * dic , char*);
node* head = (node*)malloc(sizeof(node));
node* start = (node*)malloc(sizeof(node));
int i;
node dic[50] =
{
{garen, 551, 0, 55.5, 0.625 },
{leesin, 513, 200, 59, 0.625 },
{gragas, 523, 268, 59.2, 0.651 },
{nunu, 533, 255, 54.5, 0.625 },
{riven, 500, 0, 54, 0.625 },
{jayce, 510, 280, 50, 0.658 },
{kassadin, 511, 275, 56.2, 0.638 },
{teemo, 460, 240, 47.5, 0.687},
{ahri, 460, 300, 53, 0.668},
{lux, 424, 300, 53.3, 0.668},
{lulu, 497, 255, 46.6, 0.625},
{blitzcrank, 518, 240, 59.2, 0.625},
{vayne, 442, 208, 53.3, 0.658},
{sona, 450, 310, 50, 0.644},
{elise, 475, 290, 50.5, 0.625},
{amumu, 556, 260, 50.8, 0.638},
{jax, 561, 265, 59.7, 0.638},
{thresh, 500, 244, 0.625},
{fizz, 500, 244, 0.658},
{nidalee, 460, 265, 52.5, 0.672}
};
int main()
{
int j,k;
int num;
char name2[10];
for ( j = 20; j 50; j ++ )
{
dic[j].name[0] = 0;
}
strcpy(head-name, head );
head-hp = 0;
head-mp = 0;
head-dm = 0;
head-ds = 0;
head-next = head;

start = head;
for ( k = 0; k 20; k ++ )
link(start, k );
while (1)
{
printf( 롤 딕셔너리를 시작합니다 \n );
printf( 챔피언 찾기 == 1 \n챔피언 추가 == 2 \n모든 챔피언 출력 == 3 \n가장 체력이 높은 챔피언 출력 == 4 \n삭제할 챔피언 입력 == 5 \n );
scanf ( %d, &num );
switch (num)
{
case 1:
printf( 찾을 챔피언을 입력하시오 );
scanf ( %s, name2 );
search ( dic , name2 );
break;
case 2:
printf( 추가할 챔피언을 입력하시오 );
scanf( %s, name2 );
insert ( dic , name2 );
break;
case 3 :
printf( 모든 챔피언을 출력하시오 \n );
printall( dic );
break;
case 4:
printf( 체력이 가장 높은 챔피언을 출력하시오 \n );
findmaxhealth ( dic );
break;
case 5:
printf( 삭제할 챔피언을 입력하시오 \n );
scanf ( %s, name2 );
delete ( dic , name2 );
break;
}
}
return 0;
}

void link ( node * start, int a)
{
node *node = (node*)malloc(sizeof(node));
while ( start-next != head )
start = start-next;
strcpy(node-name , dic[a].name );

node-hp = dic[a].hp;
node-mp = dic[a].mp;
node-dm = dic[a].dm;
node-ds = dic[a].ds;
node-next = head;
start -next = node;
}void search (node* start, char* name)
{
while(start-next!=head)
{
if(strcmp(start-next-name,name)==0)
{
printf(이름:%s공격력:%.1lf 체력:%d 마나:%d 공격력:%d 공격속도:%d \n,start-next-name, start-next-dm, start-next-ds, start-next-hp, start-next-dm, start-next-ds);
break;
}
start=start-next;
if(start-next == head)
printf(그런 이름을 가진 챔피언은 없습니다\n);
}
}void insert (node* tmp, char* name)
{
for ( i = 0; i 50; i ++ )
{
if ( !(strcmp(tmp[i].name , name )))
{
printf( 이미 존재하는 챔피언입니다! 다시 입력해주세요 \n\n );
break;
}
else if ( tmp[i].name[0] == 0 )
{
strcpy ( tmp[i].name , name );
printf( 체 력 : ); scanf( %d, &tmp[i].hp );
printf( 마 나 : ); scanf( %d, &tmp[i].mp );
printf( 공격력 : ); scanf( %f, &tmp[i].dm );
printf( 공격속도 : ); scanf( %f, &tmp[i].ds );
printf( 새로운 챔피언을 추가합니다 : \n);
printf( 챔피언 이름 : %s 체력 : %d 마나 : %d 공격력 : %f 공격속도 : %f \n, tmp[i].name, tmp[i].hp, tmp[i].mp , tmp[i].dm , tmp[i].dtmp[i].ds );
break;
}
}
}

void printall( node* tmp )
{
for ( i = 0; i 50; i ++ )
{
if ( !(tmp[i].name[0] == 0) )
printf(이름 : %s 체력 : %d 마나 : %d 공격력 : %f 공격속도 : %f \n, tmp[i].name, tmp[i].hp, tmp[i].mp , tmp[i].dm , tmp[i].ds );
}
printf( \n );
}

void findmaxhealth ( node* tmp )
{
int max = 0;
char name3[20];
for ( i = 0; i 50; i ++ )
{
if ( tmp[i].hp max )
{
max = tmp[i].hp;
strcpy ( name3 ,tmp[i].name );
}
else if ( tmp[i].name[0] == 0 )
{
printf( 가장 체력이 많은 챔피언 : %s \n그 챔피언의 체력 : %d \n\n, name3 , max );
break;
}
}
printf( \n );
}

void delete ( node* tmp , char* name )
{
for ( i = 0; i 50; i ++ )
{
if ( !(strcmp(tmp[i].name , name)))
{
*tmp[i].name = 0;
printf( 삭제 되었습니다 );
break;
}
else if ( tmp[i].name == 0 )
{
printf( 해당챔피언이 존재하지 않습니다 );
break;
}
}
}

신청하기





COMMENT

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

번호 제 목 글쓴이 날짜
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
2698994 날짜 계산하는 C 코드 짜고 있는데 꽉 막혀서 질문드립니다.. (6) 별 2025-06-22
2698967 파일삭제 윈도우 폴더까지 접근하게하는 함수가 뭔가요 (2) 샤인 2025-06-21
2698938 c언어 메모리질문 (3) 나래 2025-06-21
2698909 서비스 요청 고객 관리 프로그램 짜는것좀 도와주세요ㅜㅜ (4) 궁수자리 2025-06-21
2698882 프로그래밍좀 짜주세요 (3) 황예 2025-06-21
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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