(*문제 풀이)1090 테스트케이스 1번 C++
#include <iostream>
#include <vector>
#include <algorithm>
#include <numeric>
#include <string>
using namespace std;
int main()
{
int answer = 0;
int n;
cin >> n;
vector<pair<int,int>> pos(n);
for (int i = 0; i < n; ++i)
{
cin >> pos[i].first >> pos[i].second;
}
vector<int> result(n,-1);
// k번쨰 칸에 들어갈 경우
// 한 집을 정해서 최소 거리를 구한다
for (int i = 0; i < n; ++i)
{
vector<int> temp;
for (auto p2 : pos)
{
int distance = abs(pos[i].first - p2.first) + abs(pos[i].second - p2.second);
temp.push_back(distance);
}
sort(temp.begin(), temp.end());
int cnt = 0;
for (int j = 0; j < n; ++j)
{
cnt += temp[j];
if (result[j] == -1)
result[j] = cnt;
else
result[j] = min(cnt, result[j]);
}
}
for (int i = 0; i < n; i++)
{
cout << result[i] << " ";
}
return 0;
}
안녕하세요, 해당 문제 C++로 풀어서 제출해보았는데 백준 1090문제에서 안돌아가서요. 제가 봤을 때 강의 노트 풀이랑 똑같은 것 같은데 무슨 문제가 있을까요?
Answer 2
0
안녕하세요, 임보배님. 인프런 AI 인턴입니다.
백준 1090 문제의 경우, 체커가 모이는 최적의 위치를 찾고 각각의 체커가 최소한으로 이동해야 하는 횟수를 계산하게 됩니다. 제시하신 C++ 코드에서는 각 위치에서의 거리를 계산하여 가장 짧게 할 수 있는 이동 거리의 합을 계산하려고 했습니다. 다만 문제를 해결하지 못한 이유로는 몇 가지 체크해야 할 부분이 있습니다.
이중 반복문의 범위 및 조건 설정: 모든 점에서 최소 이동 거리를 구하는 것은 좋은 시작점이지만, 실제로 필요한 지점의 범위를 확인해야 합니다. 또한, ‘pos’ 벡터의 각 요소에 대해 다시 반복하는 방식인데 이 방식이 좋은 결과를 내지 못할 수 있습니다.
최소 거리 계산 및 초기화 방식:
result벡터의 초기값을-1로 설정하여 조건에 맞춰 업데이트 해주고 있는데, 처음부터 제대로 초기화되지 않은 부분이 있을 수 있습니다.result에서 최소의 거리를 계속 업데이트 하고 비교할 때 논리적으로 잘못된 부분이 있을 수 있습니다.거리 계산 로직 검토 필요: 사용자의 코드에서는 거리 계산 방식이 적절하게 나타났는지 확인하는 것이 좋습니다. 특히, 예제를 테스트하여 ‘n’의 범위와 임의의 좌표에서 제대로 동작하는지 확인해주세요.
이러한 점을 확인하여 코드 로직을 점검해 보시는 것이 좋습니다. 또한, 다음 링크에 질문이 유사하게 다루어졌으니 참고하시기 바랍니다:
- 1090완전탐색
질문이 더 있으시다면 언제든지 물어보세요. 저도 질문자님의 이해를 돕고자 지식공유자님의 기존 답변을 참고하여 유사한 답변 링크를 추천해 드리고 있습니다. 현재 베타 기능으로 답변이 만족스럽지 않을 수 있는 점 양해 부탁드립니다. 🙏 추가적으로 궁금한 점이 있으시면, 이어서 질문해 주세요. 곧 지식공유자께서 답변해 주실 것입니다.
dp[x]가 최대값이라고 확신할수 있는 이유
0
44
1
1090번 문제 질문
0
148
1
유니온파인드
0
111
1
투포인터 25:15 질문
1
127
1
#1090번 문제 반례가 궁금합니다.
0
145
1
예제코드 자바입니다
1
186
1
정수론 파트 #2247 문제에 대한 질문입니다!
0
101
0
코드 오류
0
185
1
2강 정수론 문제3 #1407 질문
0
126
0
이차원 배열 (int형)dp로 0 혹은 -1로 체크하는 방법 말고 boolean형 배열로 체크해서 바로 리턴해줄 수 없나요?
0
154
0
1717번 최적화
0
112
0
백준 22988 문제 질문
1
192
2
[Python] 백준 1090번 문제
1
223
3
강의자료에서
1
161
2
2503 문제 제한 조건 질문!
1
248
2
백준 22988 번 문제
1
191
1
추가 강의 순서
1
179
2
7강 RGB 색칠하기 질문 있습니다.
1
160
2
정수론 약수 빠르게 구하기 질문
1
255
1
1090 문제의 2, 3번째 아이디어는 결국 같은거 아닌가요?
1
372
2
1090 문제 관련하여 맨해튼 거리 최솟값에 대해 질문 있습니다.
1
222
2
누적합 문제 3번 질문
1
214
2
기억 ( 누적합 ) 강의 11660 문제
1
162
2
14719
1
204
2

