2017.04.01 12:09

핵맨

조회 수 278 추천 수 0 댓글 0

#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
#include <windows.h> 
void design(char (*a)[70], int f_maxr, int f_maxc, int dr, int dc);
void output(char (*a)[70], int f_maxr, int f_maxc, int *cnt);
int setcolor(int k);
int setsim(char (*a)[70], char (*p)[3], int x, int y, int k, int *cnt);
int removesim(char (*a)[70], int x, int y);
    
int main()
{
 char a[20][70];
    int maxr=40;
    int maxc=60;
    int cnt=0;
    
    int i, j;
    int r=10, c=35;
    char ch;
    char p[4][3] = { "▲",  "▼", "◀", "▶"};           
    int x=10, y=10, k=0;                 
                     
//디자인    
    design ( a, 20, 70, r, c);
//    setcolor(63);
//    setsim(a, p, 10, 10, 0);

    while(1) {
     y=(70+y)%70; x=(x+20)%20;
     
     if(y>=66) y=66;
     if(y<=2) y=2; 
     if(x<=1) x=1;
     if(x>=18) x=18;
     
     setsim(a, p, x, y, k, &cnt);
     
     output(a, 20, 70, &cnt);
     removesim(a, x, y);
     setcolor(7);
     
     ch=getch();
     if(ch==-32) ch=getch();
     
//     if(ch==75) {y=y-2; k=2;}
//     if(ch==77) {y=y+2; k=3;}
        int oldk=0; oldk=k;
        
        switch (ch) {
      case 72: 
            
     k=0;
     break;
      case 80: 
            
     k=1;
     break;
      case 75: 
           
     k=2;
     break;
      case 77: 
            
     k=3;
     break;
  }

     if(oldk==k) {
  
     switch (ch) {
      case 72: 
           x--; 
     
     break;
      case 80: 
           x++; 
     
     break;
      case 75: 
           y=y-2;
    
     break;
      case 77: 
           y=y+2; 
     
     break;
  }//switch
 }//if

     system("cls");
    }

    setcolor(15);
//출력

    
    return 0;
}//main

void design(char (*a)[70], int f_maxr, int f_maxc,int dr, int dc) 
{
 int i, j;
 
 for(i=0; i<f_maxr; i++) {
     for(j=0; j<f_maxc; j++) {

  a[i][j] ='A';
  if(i==0) a[i][j]='A';
  if(j==0 || j==f_maxc-1) a[i][j]='A';
  if(i==f_maxr-1) a[i][j]='A';
        }
    }
     
}

void output(char (*a)[70], int f_maxr, int f_maxc, int *cnt)
{ 
    int i, j; 
    
    for(i=0; i<20; i++) {
     setcolor((i%15)+1);
     
        for(j=0; j<70; j++) {
            printf("%c",a[i][j]);
        }
        printf("\n");
    }
    printf("cnt:%d", *cnt);
}


int setcolor(int k)
{
 HANDLE hConsole; 
 hConsole = GetStdHandle(STD_OUTPUT_HANDLE);
 SetConsoleTextAttribute(hConsole, k);
 return 0;
}

int setsim(char (*a)[70], char (*p)[3], int x, int y, int k, int *cnt) 
{
 if(a[x][y]=='A') *cnt=*cnt+2;
 if(a[x][y]=='A') printf("찾음");
 a[x][y]=p[k][0];
 a[x][y+1]=p[k][1]; 
 
 return 0;
}

int removesim(char (*a)[70], int x, int y)
{
 a[x][y]=' ';
 a[x][y+1]=' ';
} 



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 790
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1552
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2897
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 11325
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5222
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 9050
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19490
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38367
230 겁나 쉬이이이이잉이이운 가위바위보 게임 갓초딩 2017.03.25 1984
229 배열2 형성평가 3 갓초딩 2017.04.01 241
» 핵맨 선우 2017.04.01 278
227 문자열2 형성평가1 갓초딩 2017.05.06 345
226 문자열2 형성평가2 갓초딩 2017.05.06 280
225 정올 실력키우기 1147번 주사위 쌓기 문제 2 갓초딩 2017.06.25 373
224 정올 달팽이 사각형(재귀) 조정미 2017.11.18 229
223 정올 달팽이 사각형 조정미 2017.11.18 290
222 정올 달팽이 삼각형 조정미 2017.11.18 611
221 정올 대각선 지그재그 조정미 2017.11.18 774
220 정올 달팽이 삼각형(for) 조정미 2017.11.18 324
219 정올 문자마름모 조정미 2017.11.18 183
218 정올 별삼각형2 조정미 2017.11.18 321
217 정올 빙고 조정미 2017.11.18 473
216 정올 숫자마름모 조정미 2017.11.18 342
215 정올 숫자야구 조정미 2017.11.18 654
214 정올 파스칼삼각형 조정미 2017.11.18 515
213 정올 문자마름모 조정미 2017.11.25 318
212 정올 대각선지그재그 조정미 2017.11.25 371
211 정올 떡 먹는 호랑이 조정미 2017.11.25 644
Board Pagination Prev 1 ... 10 11 12 13 14 15 16 17 18 19 ... 26 Next
/ 26