250725

lililllilillll·2025년 7월 25일

개발 일지

목록 보기
243/350

✅ 한 것들


  • Atcoder
  • Frog on Lotus
  • 윤성우의 열혈 TCP/IP 소켓 프로그래밍


⚔️ Atcoder


D - Transmission Mission

#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만큼 골라서 빼면 된다. 연속해서 부분을 고르더라도 고립된 집 하나에 중계소 하나가 들어설 것이기 때문. 고로 부분 하나를 골라서 없애면 중계소가 하나 더 들어서는 대신 비용이 줄어든다.



🎮 Frog on Lotus


로직 전환 작업 진행



📖 윤성우의 열혈 TCP/IP 소켓 프로그래밍


코드를 linux에서 작성해야 하길래 노트북 꺼내긴 했는데
기왕 네트워크 프로그래밍 하는 겸, vs code가 겁나 느리기도 한 겸
neovim을 사용해보기로 함.

일단 :Tutor Lesson 2까지는 읽어놓음.

01-1 네트워크 프로그래밍과 소켓의 이해

데이터 송수신 원리 이론적으로 잘 몰라도 소켓으로 데이터 주고받을 수 있다.
송신 소켓과 수신 소켓은 다르다.

#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); // 연결 요청 수락


profile
너 정말 **핵심**을 찔렀어

0개의 댓글