2014.05.24 12:46

작대기 그리기 함수

조회 수 925 추천 수 0 댓글 0

#include <stdio.h>
#include <stdlib.h>
#include <conio.h>
void show(int arr[10][10])
{
     system("cls");
     int i,j;
     for(i=0;i<10;i++)
    { 
       for(j=0;j<10;j++)
       {  
           printf("%c ",arr[i][j]);
         
       }
        printf("\n");
    }  
}


void changij(int arr[10][10], int *pi, int *pj, char *ch, char *oldch, char *store, char *wall, int *k, char *inwall, char *point, int mode)
{
             if(*ch==*oldch)
             {
                 if(*k==1)
                 {    
                       if(mode==1 || mode==2)
                       {   
                           if(*pi==0)
                           arr[*pi][*pj]=22;
                           else if(*pi==9)
                           arr[*pi][*pj]=21;
                           else
                           arr[*pi][*pj]=16;
                       }
                       else
                       {  
                           if(*pj==0)
                           arr[*pi][*pj]=25;
                           else if(*pj==9)
                           arr[*pi][*pj]=23;
                           else
                           arr[*pi][*pj]=16;
                       }
                 }
                 else{
                     
                 if(mode==1 || mode==2) arr[*pi][*pj]='-';
                 else
                 arr[*pi][*pj]='|';
                
                 }
                
                 switch (mode){
                 case 1 :
                      *store=arr[*pi][*(pj)+1];//분석
                      if(*store!=*wall)(*pj)++; //분석
                      if(*store==' ' || *store=='-') *k=0; else *k=1;
                      break;

                 case 2 :
                      *store=arr[*pi][*(pj)-1];//분석
                      if(*store!=*wall)(*pj)--; //분석
                      if(*store==' ' || *store=='-') *k=0; else *k=1;
                      break;
                     
                 case 3 :
                      *store=arr[*(pi)-1][*pj];//분석
                      if(*store!=*wall)(*pi)--; //분석
                      if(*store==' ' || *store=='|') *k=0; else *k=1;
                      break;

                 case 4 :
                      *store=arr[*(pi)+1][*pj];//분석
                      if(*store!=*wall)(*pi)++; //분석
                      if(*store==' ' || *store=='|') *k=0; else *k=1;
                      break;

                      }
                    

//                     if(*store==' ' || *store=='-')*k=0; else *k=1;
                                         
                
             }//move

    
 }//changij
 
int main(void)
{
    char eat=' ';
    char inwall=' ';
    char point=15;
    int arr[10][10]={
        {eat,eat,eat,eat,eat,eat,eat,eat,eat,eat},
        {inwall,eat,eat,eat,inwall,eat,eat,eat,eat,eat},
        {inwall,eat,inwall,eat,inwall,eat,eat,eat,inwall,eat},
        {inwall,eat,eat,eat,inwall,eat,eat,inwall,eat,eat},
        {inwall,eat,inwall,eat,inwall,inwall,eat,eat,inwall,eat},
        {eat,eat,inwall,eat,eat,eat,eat,eat,inwall,eat},
        {eat,inwall,inwall,inwall,eat,inwall,inwall,eat,inwall,eat},
        {eat,eat,inwall,eat,eat,inwall,inwall,inwall,inwall,eat},
        {inwall,eat,inwall,inwall,eat,eat,eat,inwall,eat,eat},
        {inwall,inwall,inwall,inwall,inwall,inwall,eat,eat,eat,inwall}
        };
       
       
    inwall='*';
    int i=0, j=0;
    int pi=0, pj=0;
    char ch=-32;
    char store=eat;
    char wall=inwall;
    char oldch=14;
    int k=0;
    arr[pi][pj]=point;
    show(arr);
   
    for(;;)
    {
        if(ch!=-32)
        oldch=ch;
       
        ch=getch();
       
        if(ch==-32)
        continue;

        if((ch=='l' || ch==77) && pj<9)
        {
            point=62;          
            changij(arr, &pi, &pj, &ch, &oldch, &store, &wall, &k, &inwall, &point, 1);
    
         }//(ch=='l' || ch==77) && pj<9


        if((ch=='j' || ch==75) && pj>0)
        {
            point=60;
            changij(arr, &pi, &pj, &ch, &oldch, &store, &wall, &k, &inwall, &point, 2);

        }//if
        if((ch=='i' || ch==72) && pi>0)
        {
             point=30;
             changij(arr, &pi, &pj, &ch, &oldch, &store, &wall, &k, &inwall, &point, 3);
                 }//if 
        if((ch=='k' || ch==80) && pi<9)
        {
             point=31;
             changij(arr, &pi, &pj, &ch, &oldch, &store, &wall, &k, &inwall, &point, 4);
                 }//if            
       
       
        arr[pi][pj]=point;
        show(arr);         
         
         
          }//for

   
   
   
   
    system("pause");
    return 0;
}



List of Articles
번호 제목 글쓴이 날짜 조회 수
공지 글쓰기는 하루 5개, 댓글은 10개만 가능합니다. 좋은아빠되기 2019.02.15 298
공지 키보드 화살표값 출력 좋은아빠되기 2016.11.19 1075
공지 원하는 좌표에 값 출력하기 좋은아빠되기 2016.11.19 2390
공지 Python(파이썬) 학습 자료 PDF 1 file 좋은아빠되기 2014.12.10 10273
공지 dev C++ 텍스트 색상변경 WinApi사용(textcolor 대용) 좋은아빠되기 2014.06.07 4713
공지 DEV-C++ 기본 코드 좋은아빠되기 2013.06.19 8234
공지 무료 C++ 컴파일러(윈도우용) DEV-C++ 좋은아빠되기 2013.06.18 18945
공지 이클립스 C++ 설치 파일들 좋은아빠되기 2013.06.18 37838
170 세균전 복습 이번엔 내머리가 좀 많이 들어갓음 z키 기능 추가하고 복사 또는 이동 만들어야한다 killerjack 2014.07.05 658
169 정올 - 실력키우기 - 각 자리수의 합(2812) 조정미 2017.12.27 663
168 정올 기초다지기(함수2-자가진단6) killerjack 2014.07.26 669
167 정올 기초다지기(함수3-자가진단5)[for버전] killerjack 2014.08.16 677
166 정올 - 알고리즘 - 치즈(1840) 조정미 2018.05.05 680
165 정올 기초다지기(문자열1-자가진단9)ver 1. killerjack 2014.09.20 685
164 정올 - 실력키우기 - 숫자고르기(1459) 조정미 2018.01.27 691
163 정올 - 실전대비 - 단어맞추기(1034) 조정미 2018.05.26 701
162 정올 기초다지기(문자열1-자가진단9)ver 2. killerjack 2014.09.20 703
161 정올 기초다지기(포인터-자가진단1) killerjack 2014.11.15 713
160 정올 대각선 지그재그 조정미 2017.11.18 722
159 정올 기초다지기(문자열1-자가진단6) killerjack 2014.09.20 725
158 정올 기초다지기(함수2-자가진단8) killerjack 2014.07.26 733
157 정올 기초다지기(함수2-자가진단5) killerjack 2014.07.26 753
156 정올 - 실력키우기 - 쇠막대기(2858) 조정미 2018.01.20 754
155 정올 기초다지기(함수2-자가진단7) killerjack 2014.07.26 756
154 정올 기초다지기 (함수3-자가진단6) killerjack 2014.08.30 780
153 정올 기초다지기(함수3-형성평가6) killerjack 2014.09.20 780
152 정올 기초다지기(aD003-함수3) killerjack 2014.07.12 799
151 정올 기초다지기(함수2-자가진단2) killerjack 2014.07.12 804
Board Pagination Prev 1 ... 13 14 15 16 17 18 19 20 21 22 ... 26 Next
/ 26