2016.11.19 12:39

ㅇㅇㅇ

조회 수 115 추천 수 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 293
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1059
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2367
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10192
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 4701
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8145
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 18933
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 37821
288 정올 대각선 지그재그 조정미 2017.11.18 718
287 정올 달팽이 삼각형 조정미 2017.11.18 552
286 정올 달팽이 사각형 조정미 2017.11.18 264
285 정올 달팽이 사각형(재귀) 조정미 2017.11.18 188
284 정올 실력키우기 1147번 주사위 쌓기 문제 2 갓초딩 2017.06.25 340
283 문자열2 형성평가2 갓초딩 2017.05.06 232
282 문자열2 형성평가1 갓초딩 2017.05.06 285
281 핵맨 선우 2017.04.01 246
280 배열2 형성평가 3 갓초딩 2017.04.01 203
279 겁나 쉬이이이이잉이이운 가위바위보 게임 갓초딩 2017.03.25 1948
278 주사위 굴리기 갓초딩 2017.03.25 1414
» ㅇㅇㅇ 선우 2016.11.19 115
276 졸업문제 선우 2016.11.19 295
275 dd 승민 2016.11.19 119
274 dd 선우 2016.11.19 73
273 테두리(승민) 승민 2016.11.12 152
272 테두리(승민) 승민 2016.11.12 136
271 알파벳 배열2-1 승민 2016.10.29 185
Board Pagination Prev 1 ... 7 8 9 10 11 12 13 14 15 16 ... 26 Next
/ 26