오목 질문 3
꽃햇님
질문 제목 : 오목질문 3질문 요약 :대각선이 생각보다 너무 어려워요...ㅠㅅ ㅠ
질문 내용 :
#include stdio.h
#include windows.h
#include conio.h
#define RIGHT 77
#define LEFT 75
#define UP 72
#define DOWN 80
#define ENTER 13
void draw();
int move();
void gotoxy();
int check();
void game();
void victory();
int x=16,y=8;
int xy[32][16]={0};
char stone[3][3] = {, ○,●};
int a=1;
int count[11][11];
int main()
{
game();
while(move()){
}
return 0;
}
void game()
{
int i,j;
printf(┌┬┬┬┬┬┬┬┬┬┬┬┬┬┬┐\n);
for(i=0;i=15;i++)
{
for(j=0;j=15;j++)
{
printf(┼);
}
printf(\n);
}
printf(└┴┴┴┴┴┴┴┴┴┴┴┴┴┴┘\n);
}
void gotoxy(int x, int y)
{
COORD XY = {x, y};
SetConsoleCursorPosition(GetStdHandle(STD_OUTPUT_HANDLE), XY);
}
int move()
{
static int Turn = 0;
char c;
c = getch();
switch(c)
{
case RIGHT:
{
if(x 30)
{
x = x+2;
gotoxy(x,y);
printf(★);
}
gotoxy(x-2,y);
printf(%s, stone[xy[x-2][y]]);
if(xy[x-2][y]==0)
printf(┼);
break;
}
case LEFT:
{
if(x0)
{
x = x-2;
gotoxy(x,y);
printf(★);
}
gotoxy(x+2,y);
printf(%s, stone[xy[x+2][y]]);
if(xy[x+2][y]==0)
printf(┼);break;}
case UP:
{
if(y0)
{
y = y-1;
gotoxy(x,y);
printf(★);
}
gotoxy(x,y+1);
printf(%s, stone[xy[x][y+1]]);
if(xy[x][y+1]==0)
printf(┼);
break;}
case DOWN:
{
if(y15)
{
y = y+1;
gotoxy(x,y);
printf(★);
}
gotoxy(x,y-1);printf(%s, stone[xy[x][y-1]]);if(xy[x][y-1]==0)
printf(┼);
break;}
case ENTER:
{if(xy[x][y] == 0 && !(Turn % 2))
{
xy[x][y] = 1;
Turn++;
}
if(xy[x][y] == 0 && (Turn % 2))
{
xy[x][y] = 2;
Turn++;
}
if(check() == 0 )
return 0;
break;
}
}
return 1;
}
int check()
{
int i, j;
int count = 0;
int dol = xy[x][y];
if(dol == 0)
return 1;
//수평
for( i = 2; i 32; i+=2 )
{
if( xy[i][y] == dol && xy[i-2][y] == dol )
{
count++;
}
else
{
count = 0;
}
if( count = 4 )
{
fprintf(stdout, Victory\n);
return 0;
}
}
count = 0;
// 수직
for( j = 1; j 16; j++ )
{
if( xy[x][j] == dol && xy[x][j-1] == dol )
{
count++;
}
else
{
count = 0;
}
if( count = 4 )
{
fprintf(stdout, Victory\n);
return 0;
}
}
return 1;
/*
for(i = x-5; i= x+5; i++)//우상+좌하
{
for(j = y-5; j= y+5; j++)
{
p;if(xy[i][j] == 2){
count++;
}
}
if(count == 5 && xy[i+1][j+1] !=1){
victory();
return 0;
}
else
count=0;
}
for(i = x-5; i= x+5; i++)//우상+좌하
{
for(j = y-5; j= y+5; j++)
{
if(xy[i][j] == 2){
count++;
}
}
if(count == 5 && xy[i+1][j+1] !=1){
return 0;
victory();
}
else
count=0;
}
return 1;
}
void victory()
{
printf(victory\n);
}
번호 | 제 목 | 글쓴이 | 날짜 |
---|---|---|---|
2698012 | 2~9가아닌수 | 아놀드 | 2025-06-13 |
2697980 | for에 gets함수를 넣으니까 왜 반복이 안되죠 ㅜ (2) | 펴라 | 2025-06-12 |
2697952 | 2차배열과 함수문의^^; | VanilLa | 2025-06-12 |
2697924 | 다차원 배열 질문있습니다 | 두동 | 2025-06-12 |
2697893 | 정올 :: 기초다지기 a9007 배열7 (문제가 이상함 -_-) | 흰두루 | 2025-06-12 |
2697862 | Unable......... 지정된 파일을 찾을 수 없습니다!! (1) | Creator | 2025-06-11 |
2697761 | 그러니까여제말은... (2) | 새론 | 2025-06-10 |
2697737 | 정올 문제좀 풀어보신분~ | 레오 | 2025-06-10 |
2697709 | rand함수 질문좀요! (6) | 가막새 | 2025-06-10 |
2697683 | C언어 변수뒤 표시가 이해안되는게 있습니다. | 소미 | 2025-06-10 |
2697660 | 껍데기딜 만들고 난후 어느핫키 누르면 코드검색이라도 뜨고 그다음 무반응 해결좀 (2) | 움찬 | 2025-06-09 |
2697634 | c언어로 감성사전 만들기! (1) | 도란도란 | 2025-06-09 |
2697605 | 이 함수좀... | agine | 2025-06-09 |
2697574 | 배열 기본적인질문 (3) | 민트향 | 2025-06-09 |
2697549 | 배열 초기화 (4) | 나리 | 2025-06-08 |
2697465 | 수다님...^^ (2) | 가론 | 2025-06-08 |
2697432 | 서버 만드는 함수에서 궁금한게있어요~ | 파랑 | 2025-06-07 |
2697401 | 열혈강의 문제오류 (1) | 꿈 | 2025-06-07 |
2697374 | 기초적인 C언어 프로그래밍 입니다. | 얼 | 2025-06-07 |
2697341 | 좌우대칭 문제인데 Q가 입력되면 종료가 되야하는데 되지않습니다 | 무지개 | 2025-06-07 |