U E D R , A S I H C RSS

randomwalk/홍선

료구


Randomwalk Problem


~cpp 

== Roach.h ==

//20041004 김
const int Direction = 8;                   // 바는 8방
const int imove[8] = {-1,0,1,1,1,0,-1,-1}; // 바는 방 x  감
const int jmove[8] = {1,1,1,0,-1,-1,-1,0}; // 바는 방 y  감
int Tile[40][20] = {0,};                   // 바가 돌
int size_x, size_y;                        // x, y  
int count,t,R_count=0;                     // 바 , 랜덤 , 바가 모든 


class Roach
{
private:
		int Pos_x, Pos_y;                  // 바 
public:
	    void Initiation();                 //  
		void Input();                      // 바  
		void Walk();                       // 바는 메드
		void show();                       // 결과값 
};

void Roach :: Initiation()                 //  
{
	  cout << "가로 기를 . ( 2 < x <=40 ) \n";
	  while(!(cin >> size_x) || size_x<3 || size_x > 40)     
		  cerr << "못된 값 다. 다 .\n";
	  cout << " 기를 . ( 2 < y <=20 ) \n";
	  while(!(cin >> size_y) || size_y < 3 || size_y >20)
		  cerr << "못된 값 다. 다 .\n";
};                                         

void Roach :: Input()                      // 바  
{
	  int i,j;
	  cout << "x   \n";
	  cin >> i;
	  cout << "y   \n";
	  cin >> j;
      Pos_x = i;
	  Pos_y = j;
};


void Roach :: Walk()
{
	  t=rand()%Direction;                  // 랜덤로 바 다
	  if(Pos_x + imove[t] >= 0 && Pos_x + imove[t] < size_x) // 바로 벗 
	  Pos_x += imove[t];                                     // 바 x            
	  if(Pos_y + jmove[t] >= 0 && Pos_y + jmove[t] < size_y) 
	  Pos_y += jmove[t];                                     // 바 y  
      count++;                                               // 바  를 구 
      if(Tile[Pos_x][Pos_y]==0)
	  R_count++;	                                         // 바가 모든  방문 
	  Tile[Pos_x][Pos_y]++;                                  // 바 방문 방문 를 구다. 
};

void Roach :: show()
{
	cout << "바  는 " << count << " 다.\n";
	cout << " 는 " << Pos_x << " , " << Pos_y << "다.\n";
	cout << "각  방문 는 다과 같다. \n";
	for(int m=0; m < size_x; m++){
		for(int n=0; n < size_y; n++)
			cout << Tile[m][n] << "\t";
		    cout << endl;
	}
}






//20041004 김
#include <iostream.h>
#include <cstdlib>
#include <ctime>
#include "Roach.h"

void main()
{
	srand((unsigned)time(NULL));                   //   랜덤 
    Roach Hong;                                    // Hong 라는 Roach 
	Hong.Initiation();                             //  
	Hong.Input();                                  // 바  
	while(R_count!=size_x*size_y || count < 50000) // 바가 모든  가 50000 다
	Hong.Walk();                                   // 바 동 메드
	Hong.show();	                               // 결과값 력
}


게... 디를 고 ... 막막...
공부를 다 ㅡ_ㅡ^

Valid XHTML 1.0! Valid CSS! powered by MoniWiki
last modified 2021-02-07 05:31:44
Processing time 0.0094 sec