Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |
Tags
- 프로그래머스
- RootMotion
- algorithm
- IFileDialog
- const
- RVO
- 언리얼엔진5
- 티스토리챌린지
- 팰린드롬 만들기
- UnrealEngine5
- Programmers
- directx
- NRVO
- softeer
- 오블완
- UE5
- C
- 2294
- Unreal Engine5
- DirectX11
- UnrealEngine4
- 백준
- Frustum
- baekjoon
- 1563
- DeferredRendering
- C++
- GeeksForGeeks
- winapi
- 줄 세우기
Archives
- Today
- Total
Game Develop
[Algorithm] Programmers :: 교점에 별 만들기 본문
https://school.programmers.co.kr/learn/courses/30/lessons/87377
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
|
struct Node
{
long long y;
long long x;
};
vector<string> solution(vector<vector<int>> line) {
vector<string> map;
vector<Node> nodes;
long long minX = 10000000001;
long long maxX = -10000000001;
long long minY = 10000000001;
long long maxY = -10000000001;
long long sizeY = 0;
long long sizeX = 0;
for (int i = 0; i < line.size(); i++)
{
long long sa = line[i][0];
long long sb = line[i][1];
long long se = line[i][2];
for (int j = i + 1; j < line.size(); j++)
{
long long tc = line[j][0];
long long td = line[j][1];
long long tf = line[j][2];
long long numerator = sa * td - sb * tc; // 분모
if (numerator == 0) continue;
Node node;
long long Ydenominator = se * tc - sa * tf; // Y분자
long long Xdenominator = sb * tf - se * td; // X분자
if (Ydenominator % numerator != 0 || Xdenominator % numerator != 0) continue;
node.y = Ydenominator / numerator;
node.x = Xdenominator / numerator;
nodes.push_back(node);
if (node.y >= maxY) maxY = node.y;
if (node.y <= minY) minY = node.y;
if (node.x >= maxX) maxX = node.x;
if (node.x <= minX) minX = node.x;
}
}
sizeY = maxY - minY + 1;
sizeX = maxX - minX + 1;
map.resize(sizeY, string(sizeX, '.'));
for (int i = 0; i < nodes.size(); i++)
{
nodes[i].y = nodes[i].y - minY;
nodes[i].x = nodes[i].x - minX;
map[nodes[i].y][nodes[i].x] = '*';
}
reverse(map.begin(), map.end());
return map;
}
|
cs |
레벨2의 구현문제.
직선방정식의 각 계수가 -100,000 ~ 100,000이라 숫자를 넉넉하게 처음부터 long long으로 해놨어야했는데,
멍청하게 int로 해놨다가 '왜 안되지?' 하면서 시간 좀 날렸다.
프로그래머스에 코드를 제출했을 때는 어떤테스트케이스는 시간초과, 어떤테스트케이스는 메모리초과 같이 여러이유로 뜨길래 그냥 로직자체에 문제가 있는 줄 알았는데 사실 문제가 있을정도로 복잡한것도 아니라서 왜그런가..했는데
그냥 int로 선언했어서 그런거였다.
앞으로는 조금만 애매해도 비교수를 다 최대값으로 해야겠다.
'Algorithm > Programmers' 카테고리의 다른 글
[Algorithm] Programmers :: 숫자 게임 (1) | 2022.10.08 |
---|---|
[Algorithm] Programmers :: 합승 택시 요금 (0) | 2022.09.08 |
[Algorithm] Programmers :: 2 x n 타일링 (0) | 2022.09.05 |
[Algorithm] Programmers :: k진수에서 소수 개수 구하기 (0) | 2022.09.05 |
[Algorithm] Programmers :: 피로도 (0) | 2022.09.05 |