2017.04.01 12:09

핵맨

조회 수 307 추천 수 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 944
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1722
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 3065
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 11570
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5388
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 9236
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19659
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38551
230 겁나 쉬이이이이잉이이운 가위바위보 게임 갓초딩 2017.03.25 1993
229 배열2 형성평가 3 갓초딩 2017.04.01 251
» 핵맨 선우 2017.04.01 307
227 문자열2 형성평가1 갓초딩 2017.05.06 356
226 문자열2 형성평가2 갓초딩 2017.05.06 300
225 정올 실력키우기 1147번 주사위 쌓기 문제 2 갓초딩 2017.06.25 387
224 정올 달팽이 사각형(재귀) 조정미 2017.11.18 239
223 정올 달팽이 사각형 조정미 2017.11.18 312
222 정올 달팽이 삼각형 조정미 2017.11.18 623
221 정올 대각선 지그재그 조정미 2017.11.18 785
220 정올 달팽이 삼각형(for) 조정미 2017.11.18 336
219 정올 문자마름모 조정미 2017.11.18 193
218 정올 별삼각형2 조정미 2017.11.18 335
217 정올 빙고 조정미 2017.11.18 494
216 정올 숫자마름모 조정미 2017.11.18 370
215 정올 숫자야구 조정미 2017.11.18 666
214 정올 파스칼삼각형 조정미 2017.11.18 528
213 정올 문자마름모 조정미 2017.11.25 331
212 정올 대각선지그재그 조정미 2017.11.25 379
211 정올 떡 먹는 호랑이 조정미 2017.11.25 654
Board Pagination Prev 1 ... 10 11 12 13 14 15 16 17 18 19 ... 26 Next
/ 26