연결리스트 자꾸 오류떠요ㅠㅠ
유메
질문 제목 : 현재링크랑 서치까지 햇는데자꾸 오류뜨네요...문제가 무엇입니까...이니설라이저상수가 아니라는데 ㅠㅠ 잘모르겟습니다질문 내용 : #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;
}
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2675297 | Prity 비트 발생기 | 한란 | 2024-11-16 |
2675249 | C책 좀 추천해 주세요 (2) | 딸기우유 | 2024-11-16 |