2016.11.19 12:39

ㅇㅇㅇ

조회 수 127 추천 수 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 589
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1370
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2684
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10850
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5015
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8722
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19270
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38155
288 정올 대각선 지그재그 조정미 2017.11.18 747
287 정올 달팽이 삼각형 조정미 2017.11.18 588
286 정올 달팽이 사각형 조정미 2017.11.18 277
285 정올 달팽이 사각형(재귀) 조정미 2017.11.18 207
284 정올 실력키우기 1147번 주사위 쌓기 문제 2 갓초딩 2017.06.25 353
283 문자열2 형성평가2 갓초딩 2017.05.06 256
282 문자열2 형성평가1 갓초딩 2017.05.06 315
281 핵맨 선우 2017.04.01 261
280 배열2 형성평가 3 갓초딩 2017.04.01 220
279 겁나 쉬이이이이잉이이운 가위바위보 게임 갓초딩 2017.03.25 1972
278 주사위 굴리기 갓초딩 2017.03.25 1428
» ㅇㅇㅇ 선우 2016.11.19 127
276 졸업문제 선우 2016.11.19 303
275 dd 승민 2016.11.19 131
274 dd 선우 2016.11.19 94
273 테두리(승민) 승민 2016.11.12 180
272 테두리(승민) 승민 2016.11.12 161
271 알파벳 배열2-1 승민 2016.10.29 198
Board Pagination Prev 1 ... 7 8 9 10 11 12 13 14 15 16 ... 26 Next
/ 26