#include<iostream>
#include<vector>
#include<queue>
#include<string>
#include<algorithm>
using namespace std;
typedef long long ll;
typedef pair<int, int> pii;
int N,M; // n:house, m:base
ll cost = 0;
vector<ll> houses;
vector<ll> dist;
void Input()
{
cin >> N >> M;
houses = vector<ll>(N);
for (int i = 0; i < N; i++) {
ll x; cin >> x;
houses[i] = x;
}
sort(houses.begin(), houses.end());
}
void Dist()
{
int hs = houses.size();
for (int i = 1; i < hs; i++) {
ll d = houses[i] - houses[i - 1];
cost += d;
dist.push_back(d);
}
sort(dist.begin(), dist.end(),greater<ll>());
}
ll MinCost()
{
for (int i = 0; i < M-1; i++) {
cost -= dist[i];
}
return cost;
}
int main()
{
Input();
Dist();
cout << MinCost();
}
Editorial 봤는데 그리디로 접근한 건 똑같았음.
그거 보고 새로 짰는데도 틀려서 한참 헤맸는데
그냥 변수들을 int가 아니라 long long으로 해놨어야 했던거.
조건의 범위를 유의해야 한다.
Editorial : 각 집 사이 거리를 부분 하나라고 볼 때, 가장 비용이 큰 부분들을 M-1만큼 골라서 빼면 된다. 연속해서 부분을 고르더라도 고립된 집 하나에 중계소 하나가 들어설 것이기 때문. 고로 부분 하나를 골라서 없애면 중계소가 하나 더 들어서는 대신 비용이 줄어든다.
로직 전환 작업 진행
코드를 linux에서 작성해야 하길래 노트북 꺼내긴 했는데
기왕 네트워크 프로그래밍 하는 겸, vs code가 겁나 느리기도 한 겸
neovim을 사용해보기로 함.
일단 :Tutor Lesson 2까지는 읽어놓음.
데이터 송수신 원리 이론적으로 잘 몰라도 소켓으로 데이터 주고받을 수 있다.
송신 소켓과 수신 소켓은 다르다.
#include <sys/socket.h>
int socket(int domain, int type, int protocol); // 소켓 생성
int bind(int sockfd, struct sockaddr *myaddr, socklen_t addrlen); // 소켓에 IP 주소와 포트 번호 할당
int listen(int sockfd, int backlog); // 연결 요청 가능한 상태로 변경
int accept(int sockfd, struct sockaddr *addr, socklen_t *addrlen); // 연결 요청 수락