질문드려요 ㅠ
한뎃집
질문 제목 : 오델로인데 질문드려요입력값이요..
질문 내용 :
#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 이렇게 입력해도 입력값이 될수있는 방법좀 알려주세요 ㅠ
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
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 |