문제 6 |
하루 동안 엘리베이터가 멈춘 층이 순서대로 들어있는 배열이 있습니다. 이때, 엘리베이터의 총 이동거리를 구하려 합니다. 단, 층과 층 사이의 거리는 1입니다.
예를 들어 배열에 [1, 2, 5, 4, 2]가 들어있다면, 엘리베이터가 이동한 거리는 7입니다.
하루 동안 엘리베이터가 멈춰 선 층이 순서대로 들어있는 배열 floors가 매개변수로 주어질 때, 엘리베이터의 총 이동 거리를 return 하도록 solution 함수를 작성하려 합니다. 빈칸을 채워 전체 코드를 완성해주세요.
---
#####매개변수 설명
하루 동안 엘리베이터가 멈춘 층이 순서대로 들어있는 배열 floors가 solution 함수의 매개변수로 주어집니다.
* floors의 길이는 2 이상 100 이하입니다.
* floors의 원소는 1 이상 100 이하의 자연수이며, 인접한 두 원소의 값이 같은 경우는 주어지지 않습니다.
* floors의 첫 번째 원소는 엘리베이터의 처음 위치를 나타냅니다.
---
#####return 값 설명
엘리베이터의 총 이동 거리를 return 해주세요.
---
#####예시
floors | return |
[1, 2, 5, 4, 2] | 7 |
#####예시 설명
엘리베이터는 처음에 1층에 있으며, 다음 순서대로 움직였습니다.
* 1층 - 2층 - 5층 - 4층 - 2층
층과 층사이의 거리는 1이므로, 엘리베이터가 이동한 거리는 다음과 같습니다.
* 1층 - 2층 (이동 거리 : 1)
* 2층 - 5층 (이동 거리 : 3)
* 5층 - 4층 (이동 거리 : 1)
* 4층 - 2층 (이동 거리 : 2)
따라서 총 이동 거리는 7입니다.
[ 소스 코드 ]
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int solution(vector<int> floors) {
int dist = 0;
int length = floors.size();
for(int i = @@@; @@@; ++i){
if(@@@)
dist += floors[i] - floors[i-1];
else
dist += floors[i-1] - floors[i];
}
return dist;
}
int main() {
vector<int> floors = {1, 2, 5, 4, 2};
int ret = solution(floors);
cout << "solution ?" << ret << endl;
}
[ 정답 보기 ]
#include <string>
#include <vector>
using namespace std;
int solution(vector<int> floors) {
int dist = 0;
int length = floors.size();
for(int i = 1; i < length; ++i){
if(floors[i] > floors[i-1])
dist += floors[i] - floors[i-1];
else
dist += floors[i-1] - floors[i];
}
return dist;
}
문제 7 |
화씨온도(℉)를 섭씨온도(℃)로, 섭씨온도(℃)를 화씨온도(℉)로 바꾸려고 합니다. 두 온도 사이의 환산 공식은 다음과 같습니다.
~~~
환산공식
* 화씨온도(℉)에서 섭씨온도(℃)로 환산 : (화씨온도 - 32) ÷ 1.8 = 섭씨온도
* 섭씨온도(℃)에서 화씨온도(℉)로 환산 : (섭씨온도 x 1.8) + 32 = 화씨온도
~~~
현재 온도 value와 현재 단위 unit이 매개변수로 주어질 때, 환산한 온도의 정수 부분을 return 하도록 solution 함수를 작성했습니다. 그러나, 코드 일부분이 잘못되어있기 때문에, 몇몇 입력에 대해서는 올바르게 동작하지 않습니다. 주어진 코드에서 _**한 줄**_만 변경해서 모든 입력에 대해 올바르게 동작하도록 수정하세요.
---
#####매개변수 설명
현재 온도 value와 현재 단위 unit이 solution 함수의 매개변수로 주어집니다.
* unit은 화씨온도 "F"와 섭씨온도 "C" 둘 중 하나로 주어집니다.
* unit이 "F"인 경우 value는 화씨온도(℉)를 나타냅니다.
* unit이 "C"인 경우 value는 섭씨온도(℃)를 나타냅니다.
* value는 -460 이상 1,000 이하의 정수입니다.
---
##### return 값 설명
환산한 온도의 정수 부분을 return 해주세요.
* unit이 "F"인 경우에는 화씨온도(℉)에서 섭씨온도(℃)로 환산해주세요.
* unit이 "C"인 경우에는 섭씨온도(℃)에서 화씨온도(℉)로 환산해주세요.
---
#####예시
value | unit | return |
527 | "C" | 980 |
#####예시 설명
unit이 "C" 이므로 주어진 value는 527℃를 나타냅니다. 이를 화씨온도(℉)로 환산하면 다음과 같습니다.
(섭씨온도 x 1.8) + 32 = (527 x 1.8) + 32 = 980.6
따라서 환산 결과는 980.6℉이며, 정수 부분만 return 하면 되므로 980을 return 하면 됩니다.
[ 소스 코드 ]
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int solution(int value, string unit) {
int converted = 0;
if (unit == "C")
converted = value * 1.8 + 32;
if (unit == "F")
converted = value - 32 / 1.8;
return converted;
}
int main() {
int value = 527;
string unit = "C";
int ret = solution(value, unit);
cout << "solution ?" << ret << endl;
}
[ 정답 보기 ]
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int solution(int value, string unit) {
int converted = 0;
if (unit == "C")
converted = (value * 1.8) + 32;
if (unit == "F")
converted = (value - 32) / 1.8;
return converted;
}
문제 8 |
자연수의 각 자릿수 중에서 소수는 몇 개인지 구하려 합니다. 즉, 자연수를 각 자릿수별로 나누었을 때, 2, 3, 5, 7이 몇 개 있는지 구하려 합니다.
예를 들어, 자연수가 29022531일 때, 각 자릿수 중 소수의 위치는 다음과 같습니다.
* `2`90`2``2``5``3`1
따라서 소수의 개수는 총 5개입니다.
자연수 number가 매개변수로 주어질 때, number의 각 자릿수 중 소수는 몇 개인지 return 하도록 solution 함수를 작성했습니다. 그러나, 코드 일부분이 잘못되어있기 때문에, 몇몇 입력에 대해서는 올바르게 동작하지 않습니다. 주어진 코드에서 _**한 줄**_만 변경해서 모든 입력에 대해 올바르게 동작하도록 수정하세요.
---
#####매개변수 설명
자연수 number가 solution 함수의 매개변수로 주어집니다.
* number는 1 이상 1,000,000,000 이하의 자연수입니다.
---
#####return 값 설명
number의 각 자릿수 중 소수는 몇 개인지 return 해주세요.
---
#####예시
number | return |
29022531 | 5 |
[ 소스 코드 ]
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int solution(int number) {
int count = 0;
while(number >= 0){
int n = number % 10;
if (n == 2 || n == 3 || n == 5 || n == 7)
count +=
int n = number % 10;
1;
number /= 10;
}
return count;
}
int main() {
int number = 29022531;
int ret = solution(number);
cout << "solution ?" << ret << endl;
}
[ 정답 코드 ]
#include <string>
#include <vector>
using namespace std;
int solution(int number) {
int count = 0;
while(number > 0){
int n = number % 10;
if (n == 2 || n == 3 || n == 5 || n == 7)
count += 1;
number /= 10;
}
return count;
}
문제 9 |
N명의 후보에 대해 투표한 결과가 들어있는 배열이 있습니다. 예를 들어 5명의 후보에 대해 투표를 진행한 결과가 [2, 5, 3, 4, 1, 5, 1, 5, 5, 3]이라면 순서대로 [2번, 5번, 3번, 4번, 1번, 5번, 1번, 5번, 5번, 3번] 후보에 투표했음을 나타냅니다. 이때, 정확히 K 표를 받은 후보는 총 몇 명인지 구하려 합니다.
예를 들어 K = 2일 때, 위 투표 결과에서 정확히 2표를 받은 후보는 1번, 3번 후보로, 총 2명입니다.
투표 결과가 들어있는 배열 votes, 후보의 수 N, 표의 개수 K가 매개변수로 주어질 때, K 표를 받은 후보는 몇 명인지 return 하도록 solution 함수를 작성했습니다. 그러나, 코드 일부분이 잘못되어있기 때문에, 몇몇 입력에 대해서는 올바르게 동작하지 않습니다. 주어진 코드에서 _**한 줄**_만 변경해서 모든 입력에 대해 올바르게 동작하도록 수정하세요.
---
#####매개변수 설명
투표 결과가 들어있는 배열 votes, 후보의 수 N, 표의 개수 K가 solution 함수의 매개변수로 주어집니다.
* votes의 길이는 10 이상, 100 이하입니다.
* votes의 원소는 1 이상, 전체 후보의 수 N 이하의 자연수입니다.
* N은 3 이상 10 이하의 자연수입니다.
* K는 0 이상 100 이하의 정수입니다.
---
#####return 값 설명
K 표를 받은 후보는 몇 명인지 return 해주세요.
---
#####예시
votes | N | K | return |
[2, 5, 3, 4, 1, 5, 1, 5, 5, 3] | 5 | 2 | 2 |
#####예시 설명
각 후보가 받은 표는 다음과 같습니다.
* 1번 후보 : 2표
* 2번 후보 : 1표
* 3번 후보 : 2표
* 4번 후보 : 1표
* 5번 후보 : 4표
따라서 2표를 받은 후보는 1번, 3번 후보로 총 2명입니다.
[ 소스 코드 ]
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int solution(vector<int> votes, int N, int K) {
int counter[11] = {0};
for(int i = 0; i < votes.size(); ++i)
counter[votes[i]] += 1;
int answer = -1;
for(int i = 0; i <= N; ++i)
if(counter[i] == K)
answer += 1;
return answer;
}
int main() {
vector<int> votes = {2, 5, 3, 4, 1, 5, 1, 5, 5, 3};
int N = 5;
int K = 2;
int ret = solution(votes, N, K);
cout << "solution ?" << ret << endl;
}
[ 정답 보기 ]
#include <string>
#include <vector>
using namespace std;
int solution(vector<int> votes, int N, int K) {
int counter[11] = {0};
for(int i = 0; i < votes.size(); ++i)
counter[votes[i]] += 1;
int answer = 0;
for(int i = 0; i <= N; ++i)
if(counter[i] == K)
answer += 1;
return answer;
}
문제 10 |
A 백화점에서는 고객의 구매금액에 따라 다음과 같이 상품권을 지급합니다.
구매 금액 | 상품권 |
100만 원 이상 구매 | 5만 원 상품권 |
60만 원 이상 구매 | 3만 원 상품권 |
40만 원 이상 구매 | 2만 원 상품권 |
20만 원 이상 구매 | 1만 원 상품권 |
이때, 상품권은 지급 가능한 가장 큰 금액으로 한 장만 지급합니다. 예를 들어 고객이 65만 원을 구매했다면, 3만 원 상품권 한 장만 지급합니다.
고객들의 구매 금액이 들어있는 배열 purchase가 주어질 때, 고객들에게 지급해야 하는 상품권 총액을 return 하도록 solution 함수를 작성했습니다. 그러나, 코드 일부분이 잘못되어있기 때문에, 코드가 올바르게 동작하지 않습니다. 주어진 코드에서 _**한 줄**_만 변경해서 모든 입력에 대해 올바르게 동작하도록 수정해주세요.
---
#####매개변수 설명
고객들의 구매 금액이 들어있는 배열 purchase가 solution 함수의 매개변수로 주어집니다.
* purchase의 길이는 1 이상 100 이하입니다.
* purchase의 원소는 10 이상 1,500,000 이하의 자연수이며, 10원 단위로 주어집니다.
---
#####return 값 설명
고객들에게 지급해야 하는 상품권 총액을 return 해주세요.
---
#####예시
purchase | return |
[150000, 210000, 399990, 990000, 1000000] | 100000 |
#####예시 설명
* 210,000원, 399,990원을 구매한 고객에게 1만 원 상품권을 지급해야 합니다.
* 990,000원을 구매한 고객에게 3만 원 상품권을 지급해야 합니다.
* 1,000,000원을 구매한 고객에게 5만 원 상품권을 지급해야 합니다.
따라서 지급해야 하는 상품권은 1만 원 상품권 2장, 3만 원 상품권 1장, 5만 원 상품권 1장으로, 총액은 10만 원 입니다.
[ 소스 코드 ]
#include <iostream>
#include <string>
#include <vector>
using namespace std;
int solution(vector<int> purchase) {
int total = 0;
for(int i = 0; i < purchase.size(); ++i){
if(purchase[i] >= 1000000)
total += 50000;
else if(purchase[i] >= 600000)
total += 30000;
else if(purchase[i] >= 400000)
total += 20000;
else
total += 10000;
}
return total;
}
int main() {
vector<int> purchase = {150000, 210000, 399990, 990000, 1000000};
int ret = solution(purchase);
cout << "solution ?" << ret << endl;
}
[ 정답 보기 ]
#include <string>
#include <vector>
using namespace std;
int solution(vector<int> purchase) {
int total = 0;
for(int i = 0; i < purchase.size(); ++i){
if(purchase[i] >= 1000000)
total += 50000;
else if(purchase[i] >= 600000)
total += 30000;
else if(purchase[i] >= 400000)
total += 20000;
else if(purchase[i] >= 200000)
total += 10000;
}
return total;
}
[ 출처 ] www.ybmit.com cos pro 샘플문제
'COS Pro C++ 2급 모의고사' 카테고리의 다른 글
6. COS Pro C++ 2급 모의고사 3차(6~10번) (1) | 2024.02.28 |
---|---|
5. COS Pro C++ 2급 모의고사 3차(1~5번) (2) | 2024.02.28 |
3. COS Pro C++ 2급 모의고사 2차(1~5번) (1) | 2024.02.26 |
2. COS Pro C++ 2급 모의고사 1차(6~10번) (1) | 2024.02.26 |
1. COS Pro C++ 2급 모의고사 1차(1~5번) (0) | 2024.02.26 |