해결된 질문
작성
·
38
0
안녕하세요 선생님 🙂
최근들어 질문을 너무 많이 하는 것 같아서 정말 죄송합니다 ㅠㅠ
그만큼 절실하다는 것으로 받아들여주시면 정말 감사하겠습니다 🙂
아래는 배열이 아닌 vector<pair<int, int>> 자료형으로 문제를 풀이하였습니다.
하지만, 그동안 배열과 vector<pair<int, int>> 자료형을 많이 사용해서 그런지 vector<vector<int>> 자료형으로 변환을 해보려고 하고 있으나 풀이가 잘 안되더라구요 ㅠㅠ
코테를 많이 보진 않았지만 그동안 보았던 코테는 함수를 딸랑 하나놓고 함수를 채워나가는 형식이었는데요, 제가 기억하기로 vector<pair<int, int>>보다는 파라미터로 vector<vector<int>> 자료형이 많았던 것으로 기억합니다. 계속해서 연습하고는 있지만 잘 안되어서 도움 요청 드립니다 :)
답변 3
1
안녕하세요 유태님ㅎㅎ
질문 많이 해주셔도 됩니다. 다만 코테 합격하셔야 해요!! ㅎㅎ
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int N;
int result;
int main()
{
ios::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
cin >> N;
vector<vector<int>> vec(N, vector<int>(2));
for (int i = 0; i < N; i++)
{
cin >> vec[i][0] >> vec[i][1];
}
sort(vec.begin(), vec.end());
int Start = vec[0][0];
int End = vec[0][1];
for (int i = 1; i < N; i++)
{
if (End >= vec[i][0] && End <= vec[i][1])
{
End = vec[i][1];
}
else if (End < vec[i][0])
{
result += (End - Start);
Start = vec[i][0];
End = vec[i][1];
}
}
result += (End - Start);
cout << result << '\n';
return 0;
}
이렇게 하시면 됩니다. 😃
1
안녕하세요 유태님ㅎㅎ
질문 많이 해주셔도 됩니다. 다만 코테 합격하셔야 해요!! ㅎㅎ
#include <iostream>
#include <vector>
#include <algorithm>
using namespace std;
int N;
int result;
int main()
{
ios::sync_with_stdio(false);
cin.tie(NULL); cout.tie(NULL);
cin >> N;
vector<vector<int>> vec(N, vector<int>(2));
for (int i = 0; i < N; i++)
{
cin >> vec[i][0] >> vec[i][1];
}
sort(vec.begin(), vec.end());
int Start = vec[0][0];
int End = vec[0][1];
for (int i = 1; i < N; i++)
{
if (End >= vec[i][0] && End <= vec[i][1])
{
End = vec[i][1];
}
else if (End < vec[i][0])
{
result += (End - Start);
Start = vec[i][0];
End = vec[i][1];
}
}
result += (End - Start);
cout << result << '\n';
return 0;
}
이렇게 하시면 됩니다. 😃
0