조회 수 1121 추천 수 0 댓글 0

#include <stdio.h>
#include <stdlib.h>
#include <windows.h>
#include <conio.h>

void printstr(int d)
{
     int space=0;
     int wall=1;
     int inwall=4;
     int my=2;
     int you=3;
     int move=5;
     int setcolor[10]={1,8,13,10,15,15,15};
    
     HANDLE hConsole;

     hConsole = GetStdHandle(STD_OUTPUT_HANDLE);
     SetConsoleTextAttribute(hConsole, setcolor[d]);

     char str[10][3]={"  ","■","●","●","▧","◈","●"};
     printf("%s",&str[d][0]);
}//printstr
   
int lencheak(int maxlen)
{
    int i=1;
   
    for(i=1;i*i<maxlen;i++);
   
    return i-1;
}//lencheak
void right(int arr[100][100],int *x,int *y,int inwall, int wall,int *remember)
{
     if(arr[*x][(*y)+1]==inwall || arr[*x][(*y)+1]==wall)
     {}
     else
     {
         *remember=arr[(*x)][++(*y)];
     }
}//right
void left(int arr[100][100],int *x,int *y,int inwall, int wall,int *remember)
{
     if(arr[*x][(*y)-1]==inwall || arr[*x][(*y)-1]==wall)
     {}
     else
     {
        
         *remember=arr[(*x)][--(*y)];
     }
}//left
void up(int arr[100][100],int *x,int *y,int inwall, int wall,int *remember)
{
     if(arr[(*x)-1][*y]==inwall || arr[(*x)-1][*y]==wall)
     {}
     else
     {
         *remember=arr[--(*x)][(*y)];
     }
}//up
void down(int arr[100][100],int *x,int *y,int inwall, int wall,int *remember)
{
     if(arr[(*x)+1][*y]==inwall || arr[(*x)+1][*y]==wall)
     {}
     else
     {  
         *remember=arr[++(*x)][(*y)];
     }
}//up
void movef(int cur,int arr[100][100],int *x,int *y,int inwall, int wall,int *remember,int *zhit,int *zx,int *zy)
{  

    switch(cur)
    {
    case 77:
        
         right(arr,x,y,inwall,wall,remember);
         break;
    case 75:
        
         left(arr,x,y,inwall,wall,remember);
         break;   
    case 72:
        
         up(arr,x,y,inwall,wall,remember);
         break;        
    case 80:
        
         down(arr,x,y,inwall,wall,remember);
         break;        
    
}
}   
void movez(int cur,int arr[100][100],int *x,int *y,int inwall, int wall,int *zremember,int *zhit,int *zx,int *zy)
{
     if(*zhit==0) *zhit=1;
     else
     {   
          *zhit=0;
          arr[*x][*y]=*zremember;
          }
    
    
     *zx=*x;
     *zy=*y;
     *zremember=arr[*x][*y];
     printf("제트리멤버 %d",*zremember);
     system("pause");
}
  
int main(void)
{
    int x;
    int y;
    int ch;
    int i;
    int j;
    int maxlen;
    int stagenum;
    int arr[100][100];
    char cur=-32;
    char oldcur;
    int space=0;
    int wall=1;
    int inwall=4;
    int my=2;
    int you=3;
    int move=5;
    int remember=space;
    int zx=0;
    int zy=0;
    int zhit=0;
    int zremember=0;

    FILE *fp=fopen("stage1.txt","r");
    if(fp==NULL)
    {  
        puts("파일오픈 실패!");
        return -1;
        }
   
    fscanf(fp,"%d", &maxlen);
    fscanf(fp,"%d", &stagenum);

   
    //데이터 읽음.   
    for(i=0;i<lencheak(maxlen);i++)
    {
         for(j=0;j<lencheak(maxlen);j++)
         {
             fscanf(fp,"%d", &ch);
             arr[i][j]=ch;
         }
    }
   
    //커서 세팅.
    x=lencheak(maxlen)/2;
    y=x;
    arr[x][y]=5;
   
   
   
    while(1)
    {
           
            system("cls");
    //데이터 출력.
    for(i=0;i<lencheak(maxlen);i++)
    {   
         for(j=0;j<lencheak(maxlen);j++)
         {   
              if(zhit==1 && zx==i && zy==j) printstr(6);
              else
              printstr(arr[i][j]);
         }
             
         printf("\n");
         }

         for(;;)
         {
              if(cur!=-32)
              oldcur=cur;
       
              cur=getch();
       
              if(cur!=-32)
              break;
        }
       
        arr[x][y]=remember;
        if((cur=='z' && arr[x][y]!=space) || (cur=='z' && zhit==1))
        movez(cur,arr,&x,&y,inwall,wall,&zremember,&zhit,&zx,&zy);
        else              
        movef(cur,arr,&x,&y,inwall,wall,&remember,&zhit,&zx,&zy);
       
        arr[x][y]=move;
       
    }//while end
 
    fclose(fp);
    system("pause");
    return 0;
}



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 587
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1365
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2680
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10847
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 5015
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8720
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 19263
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 38152
110 정올 기초다지기(함수3-자가진단3) killerjack 2014.07.26 904
109 정올 기초다지기(함수3-자가진단2) killerjack 2014.07.26 600
108 정올 기초다지기(함수3-자가진단1) killerjack 2014.07.26 895
107 정올 기초다지기(aE007-함수2 7) killerjack 2014.07.26 1002
106 정올 기초다지기(aE006-함수2 6) killerjack 2014.07.26 669
105 정올 기초다지기(aE005-함수2 5) killerjack 2014.07.26 646
104 정올 기초다지기(aE002-함수2 2) killerjack 2014.07.26 593
103 정올 기초다지기(함수2-자가진단8) killerjack 2014.07.26 752
102 정올 기초다지기(함수2-자가진단7) killerjack 2014.07.26 776
101 정올 기초다지기(함수2-자가진단6) killerjack 2014.07.26 690
100 정올 기초다지기(함수2-자가진단5) killerjack 2014.07.26 775
99 정올 기초다지기(함수2-자가진단4) killerjack 2014.07.12 816
98 정올 기초다지기(함수2-자가진단3) killerjack 2014.07.12 1127
97 정올 기초다지기(함수2-자가진단2) killerjack 2014.07.12 818
96 정올 기초다지기(함수2-자가진단1) killerjack 2014.07.12 906
95 정올 기초다지기(aD004-함수4) killerjack 2014.07.12 946
94 정올 기초다지기(aD003-함수3) killerjack 2014.07.12 816
93 세균전 복습 이번엔 내머리가 좀 많이 들어갓음 z키 기능 추가하고 복사 또는 이동 만들어야한다 killerjack 2014.07.05 681
» 세균전 복사하기 만들어야함 killerjack 2014.06.07 1121
91 dev C++ 입력키값 숫자로 알아보기 killerjack 2014.06.07 1345
Board Pagination Prev 1 ... 16 17 18 19 20 21 22 23 24 25 26 Next
/ 26