질문드려요 ㅠ
한뎃집
질문 제목 : 오델로인데 질문드려요입력값이요..
질문 내용 :
#include stdio.h
#include windows.h
void gotoxy(int x, int y);
void main()
{
int save[8][8] = {0, };
int delta_x[8] = {1, 1, 0, -1, -1, -1, 0, 1}; // 3시 위치부터 시계방향
int delta_y[8] = {0, 1, 1, 1, 0, -1, -1, -1}; // 3시 위치부터 시계방향
int x, y; // 입력 좌표
int xi, yi; // 조사를 하기 위한 좌표
int i, j, k;
int turn = 2; // 순서
int count1 = 0, count2 = 0; // 백돌수, 흑돌수
int dir, changed; // 조사방향(8방향), 변화된 돌 수
printf( 0 1 2 3 4 5 6 7 \n); //흑돌 2 백돌 1
printf( ┏━━┳━━┳━━┳━━┳━━┳━━┳━━┳━━┓\n);
printf( 0 ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 1 ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 2 ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 3 ┃ ┃ ┃ ┃ ● ┃ ○ ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 4 ┃nbsp; ┃ ┃ ┃ ┃ ○ ┃ ● ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 5 ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 6 ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃\n);
printf( ┣━━╋━━╋━━╋━━╋━━╋━━╋━━╋━━┫\n);
printf( 7 ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃ ┃\n);
printf( ┗━━┻━━┻━━┻━━┻━━┻━━┻━━┻━━┛\n);
save[3][3] = 2;
save[4][4] = 2;
save[3][4] = 1;
save[4][3] = 1;
while(1)
{
gotoxy(0, 20); //입력부분, 잘못된 입력입니다 올바르게 입력했을경우 화면 클리어
printf( );
gotoxy(0, 21);
printf( );
gotoxy(0, 22);
printf( );
// 돌이 다 놓여졌으면 게임끝
if(count1 + count2 == 64) break;
while(1)
{
gotoxy(0, 19);
if(turn == 2)
printf(흑돌의 차례입니다.);
else
printf(백돌의 차례입니다.);
gotoxy(0, 18);
printf(입력은 가로좌표부터입니다.);
gotoxy(0, 20);
scanf(%d %d,&x,&y); //배열 좌표를 입력
// 바뀌는 돌이 있는지 조사
// 방금 놓인 돌의 좌료를 중심으로 8방향을 조사하여
// 연속적으로 상대 돌이 존재하고 그 끝에 자신의 돌이 있으면 바꿀 수 있다
// 즉, 상대방 돌을 가로막을 수 있으면 그 돌들 모두를 자신의 돌로 바꿀 수 있다
changed = 0; // 바뀐 돌 수
for(dir = 0; dir 8; dir++) // 8방향 조사
{
xi = x; // 기준 좌표
yi = y; // 기준 좌표
j = 0; // 현재 방향에서 연속된 상대 돌 수
for(i = 0; i 7; i++) // 현재방향에서 1씩 증가 또는 감소
{
xi += delta_x[dir]; // 검사 위치 좌표
yi += delta_y[dir]; // 검사 위치 좌표
if(xi 0 || xi 7 || yi 0 || yi 7 || save[xi][yi] == 0) // 범위를 벗어나면 조사 중단
break;
if(save[xi][yi] == turn) // 자신의 돌이 발견되면
{
for( ; i 0; i--) // 역으로 추적하면서 상대 돌을 자신의 돌로 바꿈
{
xi -= delta_x[dir];
yi -= delta_y[dir];
save[xi][yi] = turn;
}
changed += j; // 방향 전체를 통해 바뀔 수 있는 돌 수 증가
break;
}
j++; // 현재 방향에서 연속된 상대 돌 수 증가
}
}
// 전체 방향으로 모두 조사한 후 바꿀 수 있는 돌이 있다면
if(changed)
p; {
save[x][y] = turn; // 방금 놓은 위치
count1 = count2 = 0; // 전체 돌 수 계산
for(i = 0; i 8; i++)
{
for(j = 0; j 8; j++)
{
if(save[i][j] == 2)
{
gotoxy(i * 6 + 7, j * 2 + 2);
printf(○);
count2++;
}
else if(save[i][j] == 1)
{
gotoxy(i * 6 + 7, j * 2 + 2);
printf(●);
count1++;
}
}
}
turn = 3 - turn; // 상대방으로 순서 바꿈
}
else
{
gotoxy(0, 22);
printf(잘못된 입력입니다.);
}
}
}
gotoxy(0, 22);
printf(백돌 : %d개, 흑돌 : %d개\n, count1, count2);
if(count1 count2)
printf(백이 승리하였습니다.\n);
else if(count2 count1)
printf(흑이 승리하였습니다.\n);
else
printf(서로 비겼습니다.\n);
}
void gotoxy(int x, int y)
{
coord cur;
cur.x = x;
cur.y = y;
setconsolecursorposition(getstdhandle(std_output_handle), cur);
}
오델로 소스인데요. 지금 입력은 3 5 이렇게 한칸띄워서 입력받는건데
35 이렇게 입력해도 입력값이 될수있는 방법좀 알려주세요 ㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2654881 | PID 모듈 검색 부분 질문합니다 . | 이름없음 | 2024-05-14 |
2654850 | 조건에 만족하는 다음 수를 찾고 싶습니다. | 초엘 | 2024-05-14 |
2654790 | 두파일간 byte단위 txt파일 복사 中 | 슬찬 | 2024-05-14 |
2654768 | 사전만들기 입니다. | 여우By | 2024-05-13 |
2654716 | c언어 고수님들 답좀적어주세요 급합니다 ㅠㅠ | 한말글 | 2024-05-13 |
2654688 | c언어 ㅠㅠ 너 무 어려 워요 ㅠ 도와주세요!! | 별빛 | 2024-05-13 |
2654659 | 구구단 소스 궁금한 점 도움 부탁드립니다! (2) | 미련곰팅이 | 2024-05-12 |
2654633 | 오류가 무었인가요..? (2) | 단순랩퍼 | 2024-05-12 |
2654603 | 어디가 잘못된지를 모르겠습니다. 한 번 봐주세요...ㅠ (2) | 글고운 | 2024-05-12 |
2654574 | 소스 추가좀 부탁드립니다. (등수 출력) | 크리미걸 | 2024-05-12 |
2654550 | 피보나치수열. (3) | 중독적 | 2024-05-11 |
2654521 | c초보 빙고관련게임... | 달콤이 | 2024-05-11 |
2654491 | 10진수를 2진수로 바꾸는법 (8) | 아잉 | 2024-05-11 |
2654412 | 빅오를 구하고 싶어요~ | 애기 | 2024-05-10 |
2654381 | 혼자 연구하는 c/c++ 질문 | 아잉 | 2024-05-10 |
2654352 | 행렬크기를 scanf로 입력받을수도 있나요..? | VanilLa | 2024-05-10 |
2654293 | 첫시작값과 끝값의 사이에 존재하는 정수들의 합을 구하는 것 (5) | 해긴 | 2024-05-09 |
2654185 | 64bit 환경에서 자료형의 크기가 좀궁그해요(완료) 더궁금한게 생겻어요(추가) (2) | 빈길 | 2024-05-08 |
2654152 | 확장자 exe로 변경 (1) | 한 | 2024-05-08 |
2654128 | c언어 간단하게 자판기만들려는데 ㅜㅜ | 유1혹 | 2024-05-08 |