연결리스트 자꾸 오류떠요ㅠㅠ
유메
질문 제목 : 현재링크랑 서치까지 햇는데자꾸 오류뜨네요...문제가 무엇입니까...이니설라이저상수가 아니라는데 ㅠㅠ 잘모르겟습니다질문 내용 : #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;
}
}
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |
2691483 | 파일 오픈시 에러 질문드립니다. (2) | 호습다 | 2025-04-14 |
2691450 | [visual c++ 툴]기초 질문 (3) | 해긴 | 2025-04-13 |