수다닷컴

  • 해외여행
    • 괌
    • 태국
    • 유럽
    • 일본
    • 필리핀
    • 미국
    • 중국
    • 기타여행
    • 싱가폴
  • 건강
    • 다이어트
    • 당뇨
    • 헬스
    • 건강음식
    • 건강기타
  • 컴퓨터
    • 프로그램 개발일반
    • 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

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

번호 제 목 글쓴이 날짜
2700368 if에 관해서 질문이요... Orange 2025-07-04
2700339 이거 결과값이 왜이런건지.. (4) 그댸와나 2025-07-04
2700313 파일 읽어서 저장하는데 빈파일일 경우 문재가 발생하네요.. (2) 크나 2025-07-03
2700287 구조체 동적할당 연습을 하는데 오류가 뜹니다...(해결) (3) 아련나래 2025-07-03
2700264 문자와 숫자 동시에 입력??? 글고운 2025-07-03
2700236 txt파일로만 쓰고 읽게 하려면 어떻게 해야 하나요..?? (8) 미국녀 2025-07-03
2700211 전위 연산자 (2) 어른처럼 2025-07-02
2700183 C에서 파일이름을 받고, 그 파일의 사이즈를 출력해줘야하는데 내용이 출력이 안되네요 ;ㅅ; 피스케스 2025-07-02
2700150 꼭좀 도와주세요ㅠㅠㅠ 호습다 2025-07-02
2700095 연산문제...질문... 오빤테앵겨 2025-07-01
2700070 while문 , 3의배수 출력하는 프로그램좀 짜주세욤. 횃불 2025-07-01
2700041 초보인데요 ㅎ 배열안에 배열을 집어넣을수 있나요?? 헛장사 2025-07-01
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
<<  이전  1 2 3 4 5 6 7 8 9 10  다음  >>

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