분류 전체보기
- 나히아 4기 13화 명장면 2020.01.29
- Founders X SAMSUNG Blockchain 3기 2020.01.29
- [백준] 14499-주사위 굴리기 2020.01.29
- [백준] 3190-뱀 2020.01.29
나히아 4기 13화 명장면
2020. 1. 29. 17:01
Founders X SAMSUNG Blockchain 3기
2020. 1. 29. 16:53
반응형
앞으로 배우는 내용들 포스팅할 예정입니다! :)
열심히 하겠습니다.
반응형
'Blockchain 개발 > Founders X SAMSUNG Blockchain' 카테고리의 다른 글
Founders X SAMSUNG Blockchain 브이로그 영상입니다 : ) (0) | 2020.04.04 |
---|---|
블록체인 서비스란? (0) | 2020.02.05 |
블록체인 플랫폼이란?(트랜잭션, 블럭, 스마트 컨트렉터 (0) | 2020.02.05 |
블록체인이란? (0) | 2020.02.03 |
[백준] 14499-주사위 굴리기
2020. 1. 29. 16:35
반응형
시뮬레이션 문제같은 경우에는 미리 청사진을 자세하게 그려놓고 문제를 풀이하는게 중요합니다.
문제에서 요구하는 조건을 꼼꼼히 확인하고 단계별로 코딩을 하면 쉽게 풀 수 있는 문제였습니다.
주석하는 습관, 디버깅습관을 기를 수 있는 좋은 문제입니다.
// 동 서 남 북 1 2 3 4
/*
1. 이동할 수 있는 구간인지 확인하고 불가능하면 continue로 이동하지말구 나가기 O
2. 좌표변경 후, 이동할 수 있으면 주사위 쉐이킹 O
3. 바닥이 0이면 바닥에 주사위의 해당수를 넣기 O
4. 바닥이 0이 아니면 칸에 쓰여 있는 수가 주사위의 바닥면으로 복사되며, 칸에 쓰여 있는 수는 0이 된다. O
5. 윗면 dice[1]을 출력한다. O
*/
#include <iostream>
using namespace std;
int n, m, x, y, k;
int arr[21][21] = { 0 };
int karr[1000] = { 0 };
int dice[7] = { 0, }; // 인덱스 순서대로 값을 나타내는것 6번째가 항상 아래가 되는 구조인거지
void verifydice(int direction) {
int temp = 0;
if (direction == 1) {
temp = dice[6];
dice[6] = dice[3];
dice[3] = dice[1];
dice[1] = dice[4];
dice[4] = temp;
// 2랑 5는 동일한 구조
}
else if (direction == 2) {
temp = dice[6];
dice[6] = dice[4];
dice[4] = dice[1];
dice[1] = dice[3];
dice[3] = temp;
// 2랑 5는 동일한 구조
}
else if (direction == 3) {
temp = dice[6];
dice[6] = dice[5];
dice[5] = dice[1];
dice[1] = dice[2];
dice[2] = temp;
// 3랑 4는 동일한 구조
}
else if (direction == 4) {
temp = dice[6];
dice[6] = dice[2];
dice[2] = dice[1];
dice[1] = dice[5];
dice[5] = temp;
// 3랑 4는 동일한 구조
}
}
int main() {
cin >> n >> m >> x >> y >> k; //입력1 (x,y)
for (int i = 0; i < n; i++) //입력2
for (int j = 0; j < m; j++)
cin >> arr[i][j];
for (int i = 0; i < k; i++) //입력3
cin >> karr[i];
for (int s = 0; s < k; s++) { // k번 만큼 횟수
if (karr[s] == 1) { // 동쪽으로 이동할때
if ((y + 1) >= m)
continue;
y++;
verifydice(1);
}
else if (karr[s] == 2) { //서쪽으로 이동할때
if ((y - 1) < 0)
continue;
y--;
verifydice(2);
}
else if (karr[s] == 4) { //남쪽으로 이동할때
if ((x + 1) >= n)
continue;
x++;
verifydice(3);
}
else if (karr[s] == 3) { //북쪽으로 이동할때
if ((x - 1) < 0)
continue;
x--;
verifydice(4);
}
//3,4번의 기능을 구현
if (arr[x][y] == 0)
arr[x][y] = dice[6];
else {
dice[6] = arr[x][y];
arr[x][y] = 0;
}
//5번
cout << dice[1] << endl;
}
}
반응형
'알고리즘 > 시뮬레이션' 카테고리의 다른 글
[백준] 11559-Puyo Puyo(C++) (0) | 2020.05.03 |
---|---|
[백준] 14891-톱니바퀴(C++) (0) | 2020.04.28 |
[백준] 14500-테트로미노(C++) (0) | 2020.04.14 |
[백준] 1021-회전하는 큐(C++) (0) | 2020.04.02 |
[백준] 3190-뱀 (0) | 2020.01.29 |
[백준] 3190-뱀
2020. 1. 29. 16:32
반응형
시뮬레이션 문제같은 경우에는 미리 청사진을 자세하게 그려놓고 문제를 풀이하는게 중요합니다.
문제에서 요구하는 조건을 꼼꼼히 확인하고 단계별로 코딩을 하면 쉽게 풀 수 있는 문제였습니다.
주석하는 습관, 디버깅습관을 기를 수 있는 좋은 문제입니다.
/*
1. 값 입력받기 ok
2. 현재 방향에 따라 뱀 이동시키기 (이동규칙 3가지는 문제 참조) ok
4방향으로 구분, 사과가 있을때와 사과가 없을때로 구분 ok
3. 이때 벽이거나 자기에게 닿으면 종료 ok
4. 방향전환을 해야하는지 확인 ok
*/
#include <iostream>
using namespace std;
typedef struct snaketurn
{
int x;
char c;
}snaketurn;
int n, k,l;
int arr[101][101] = { 0, };
int yy, xx; //입력을 위한
snaketurn turned[100];
int snakeEnd = 0; // X가 증가하는 순으로 주어지니까 포인터를 만든 것
int sec = 0, currentDirection = 1;
int snake[101][2] = { 0, }; //뱀의 좌표를 저장해둘 공간들 행, 열 순
int snakePointer = 0;
int lasty = 0, lastx = 0;
void modify();
void changedirection();
int main() {
cin >> n;
cin >> k;
for (int i = 0; i < k; i++) {
cin >> yy >> xx;
arr[yy][xx] = 1;
}
cin >> l;
for (int i = 0; i < l; i++)
cin >> turned[i].x >> turned[i].c;
//1
snake[0][0] = 1, snake[0][1] = 1; //처음에 뱀의 위치를 지정
while (1) {
bool jud = false;
sec++;
modify(); //2
// ------------------3----------------------
if (snake[0][0]<1 || snake[0][1]<1 || snake[0][0]>n || snake[0][1]>n) //벽에 부딪힐때
break;
for (int i = 1; i <= snakePointer; i++) { //자기 자신한테 부딪히는지 확인
if (snake[0][0] == snake[i][0] && snake[0][1] == snake[i][1]) {
jud = true;
break;
}
}
if (jud == true)
break;
if (lastx == snake[0][1] && lasty == snake[0][0])
break;
//--------------------4------------------
changedirection(); //4
}
cout << sec << endl;
}
void modify() {
lasty = snake[snakePointer][0], lastx = snake[snakePointer][1];
if (currentDirection == 1) { //오른쪽 방향
if (arr[snake[0][0]][snake[0][1] + 1] == 1) {//이동할 공간에 사과가 있다면
arr[snake[0][0]][snake[0][1] + 1] = 0; //0으로 초기화
snakePointer++;
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][1] = snake[0][1] + 1; //오른쪽으로 한방향 이동
}
else { //사과가 없을때
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][1] = snake[0][1] + 1; //오른쪽으로 한방향 이동
}
}
else if (currentDirection == 2) { //아래방향
if (arr[snake[0][0] + 1][snake[0][1]] == 1) {//이동할 공간에 사과가 있다면
arr[snake[0][0] + 1][snake[0][1]] = 0;
snakePointer++;
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][0] = snake[0][0] + 1; //아래로 한칸이동
}
else { //사과가 없을때
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][0] = snake[0][0] + 1; //아래로 한칸이동
}
}
else if (currentDirection == 3) { //왼쪽 방향
if (arr[snake[0][0]][snake[0][1] - 1] == 1) {//이동할 공간에 사과가 있다면
arr[snake[0][0]][snake[0][1] - 1] = 0; //0으로 초기화
snakePointer++;
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][1] = snake[0][1] - 1; //오른쪽으로 한방향 이동
}
else { //사과가 없을때
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][1] = snake[0][1] - 1; //오른쪽으로 한방향 이동
}
}
else if (currentDirection == 4) { //위로 이동하는경우
if (arr[snake[0][0] - 1][snake[0][1]] == 1) {//이동할 공간에 사과가 있다면
arr[snake[0][0] - 1][snake[0][1]] = 0;
snakePointer++;
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][0] = snake[0][0] - 1; //아래로 한칸이동
}
else { //사과가 없을때
for (int i = snakePointer; i > 0; i--) {
snake[i][0] = snake[i - 1][0];
snake[i][1] = snake[i - 1][1];
}
snake[0][0] = snake[0][0] - 1; //아래로 한칸이동
}
}
}
void changedirection() {
if (turned[snakeEnd].x == sec) {
if (currentDirection == 1) {
if (turned[snakeEnd].c == 'D')
currentDirection = 2;
else
currentDirection = 4;
}
else if (currentDirection == 2) {
if (turned[snakeEnd].c == 'D')
currentDirection = 3;
else
currentDirection = 1;
}
else if (currentDirection == 3) {
if (turned[snakeEnd].c == 'D')
currentDirection = 4;
else
currentDirection = 2;
}
else if (currentDirection == 4) {
if (turned[snakeEnd].c == 'D')
currentDirection = 1;
else
currentDirection = 3;
}
snakeEnd++;
}
}
반응형
'알고리즘 > 시뮬레이션' 카테고리의 다른 글
[백준] 11559-Puyo Puyo(C++) (0) | 2020.05.03 |
---|---|
[백준] 14891-톱니바퀴(C++) (0) | 2020.04.28 |
[백준] 14500-테트로미노(C++) (0) | 2020.04.14 |
[백준] 1021-회전하는 큐(C++) (0) | 2020.04.02 |
[백준] 14499-주사위 굴리기 (0) | 2020.01.29 |