2017.04.01 12:09

핵맨

조회 수 246 추천 수 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 298
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1079
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2394
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10303
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 4719
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8267
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 18955
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 37860
310 정올 함수1 자가진단8 정승준 2018.12.15 244
» 핵맨 선우 2017.04.01 246
308 정올 - 실력키우기 - 버블정렬(1157) 조정미 2017.12.23 246
307 정올 - 실력키우기 - 문자열 찾기(2514) 조정미 2018.01.03 246
306 test killerjack 2014.12.20 247
305 2진수를 8진수로 조정미 2017.12.09 249
304 링크드 리스트 예제 조정미 2018.03.03 251
303 정올 - 문제은행 - 십자 카드 문제(1018) - Time Limit Exceed 조정미 2018.07.07 256
302 정올 - 실력키우기 - 별삼각형3(1329) 조정미 2017.12.27 257
301 정올 - 실력키우기 - 별삼각형1(1523) 조정미 2017.12.27 258
300 정올 - 문제은행 - 가장 많이 나온 자연수(1069) 조정미 2018.06.23 261
299 반복제어문3 형성평가 1 선우 2016.03.19 264
298 정올 달팽이 사각형 조정미 2017.11.18 264
297 정올 함수1 자가진단4 정승준 2018.12.08 264
296 정올 - 알고리즘 - 색상환(2264) - Time Limit Exceed 조정미 2018.05.05 267
295 문자10개 띄어쓰기 무시하는거랑 역순으로 출력하기(승민) 승민 2016.04.02 268
294 정올 함수1 자가진단7 정승준 2018.12.15 269
293 정올 기초다지기(파일입출력-자가진단4)미완성 killerjack 2015.04.11 274
292 제곱근 구하고 그사이 숫자 구하기(승민) 승민 2016.08.13 275
291 정올 반복제어문2 형성평가 6 선우 2016.03.11 276
Board Pagination Prev 1 ... 6 7 8 9 10 11 12 13 14 15 ... 26 Next
/ 26