회원가입
로그인
Toggle navigation
문제
문제
전체 문제
문제 출처
단계별로 풀어보기
알고리즘 분류
추가된 문제
문제 순위
문제
푼 사람이 한 명인 문제
아무도 못 푼 문제
최근 제출된 문제
최근 풀린 문제
랜덤
출처
ICPC
Olympiad
한국정보올림피아드
한국정보올림피아드시․도지역본선
전국 대학생 프로그래밍 대회 동아리 연합
대학교 대회
카카오 코드 페스티벌
Coder's High
ICPC
Regionals
World Finals
Korea Regional
Africa and the Middle East Regionals
Europe Regionals
Latin America Regionals
North America Regionals
South Pacific Regionals
문제집
대회
2
채점 현황
랭킹
게시판
그룹
더 보기
재채점 기록
블로그
강의
실험실
도움말
BOJ Stack
BOJ Book
전체
공지
자유
질문
오타/오역/요청
게시판 공지
홍보
업데이트
solved.ac
글쓰기
질문 도움말
자주묻는 질문
테스트 케이스 반례 검색은 맞는데 어디가 틀린지 모르겠네요..
17135번 - 캐슬 디펜스
culture1123
4년 전
0
dfs로 궁수 세명의 위치를 정한다.
마지막 행 부터 처음 행까지 이동시키며 검색한다
검색은 최대거리 행에서 부터 검색
map 한칸 씩 당겨준다
몇시간째 풀고있는데 답을 모르겟네요...
궁수 별로 각각 검색하는 로직으로 풀었습니다
도와주세요 고수님들..
#include <iostream> #include <string.h> #include <algorithm> using namespace std; int n, m, d; int map[16+1][16]; int visit[16]; int ans = 0; int a[3]; int aa, ab, ac; //궁수 3명의 위치 fir, se, th void go(int fir, int se, int th) { int numgo = 0; int nn = n; int cntt = 0; while (true) { //끝부터 처음 까지 이동다했으면 종료 if (numgo == m+1) { if (cntt > ans) { ans = cntt; } return; } //a쏜다 int shoots=0, shootc=100; int dist1 = 10; int dist = 0; int flag1 = 0; int a1, a2=100, b1, b2=100, c1, c2=100; //검색에서 동시에 쏜다 유의해서 위치를 a1...c2로 잡음 //최대 거리 행에서 부터 검색 //fir 검색시작 for (int i = n - 1; i >= n - d; i--) { for (int j = 0; j < m; j++) { //적이 있을때 거리가 d 이내이고 최소 d 이고 제일 왼쪽에 있는거 검색 if (map[i][j] == 1) { dist = abs(n - i) + abs(j - fir); if (dist <= d) { if (dist <= dist1) { dist1 = dist; if (j < a2) { flag1 = 1; a1 = i; a2 = j; } } } } } } dist1 = 10; dist = 0; //a랑 같은 로직으로 검색 int flag2 = 0; for (int i = n - 1; i >= n - d; i--) { for (int j = 0; j < m; j++) { if (map[i][j] == 1) { dist = abs(n - i) + abs(j - se); if (dist <= d) { if (dist <= dist1) { dist1 = dist; if (j < b2) { flag2 = 1; b1 = i; b2 = j; } } } } } } //c쏜다 //c와 같은 로직으로 검색 shoots = 0, shootc = 100; dist1 = 10; dist = 0; int flag3 = 0; for (int i = n - 1; i >= n - d; i--) { for (int j = m-1; j >=0 ; j--) { if (map[i][j] == 1) { dist = abs(n - i) + abs(j - th); if (dist <= d) { if (dist <= dist1) { dist1 = dist; if (j < c2) { flag3 = 1; c1 = i; c2 = j; } } } } } } //거리 이내에 있다면 각각 검색한다 if (flag1 == 1) { map[a1][a2] = 0; cntt++; } if (flag2 == 1) { if (map[b1][b2] == 1) { map[b1][b2] = 0; cntt++; } } if (flag3 == 1) { if (map[c1][c2] == 1) { map[c1][c2] = 0; cntt++; } } //한칸씩 전진 for (int i = n-1; i >=0; i--) { for (int j = 0; j < m; j++) { if (i == n - 1) { map[i][j] = 0; } else { int temp = map[i][j]; map[i + 1][j] = temp; map[i][j] = 0; } } } numgo++; } } // 3개 정하고 dfs 시작 void solve(int cnt,int num) { if (num == m) { if (cnt == 3) { int mapc[16+1][16]; memcpy(mapc, map, sizeof(map)); int b = 0; for (int i = 0; i < m; i++) { if (visit[i] == 1) { a[b] = i; b++; } } aa = a[0]; ab = a[1]; ac = a[2]; go(aa,ab,ac); memcpy(map, mapc, sizeof(map)); return; } return; } visit[num] = 0; solve(cnt , num+1); visit[num] = 1; solve(cnt + 1 , num+1); } int main() { cin >> n >> m >> d; for (int i = 0; i < n; i++) { for (int j = 0; j < m; j++) { int x; cin >> x; map[i][j] = x; } } solve(0,0); cout << ans << endl; return 0; }
댓글을 작성하려면
로그인
해야 합니다.
culture1123 4년 전
몇시간째 풀고있는데 답을 모르겟네요...
궁수 별로 각각 검색하는 로직으로 풀었습니다
도와주세요 고수님들..