목록전체 글 (360)
연습을 위해서 다양하게 코드를 수정해 본다. 1. 자신이 입력한 것을 전송하기클라이언트의 코드이다.message에 입력을 받아 send로 서버에 전송해 준다. message.data()가 아닌 message.c_str()로 전송하는 게 더욱 안전하다고 한다.string타입일 때는 c스타일로 변환해서 전송을 해야 한다. 2. 클라이언트에게 받은 문자열을 뒤집어서 다시 전송하기recv로 buffer에 문자열을 담고 string으로 바꾸어준다.문자열을 뒤집고 다시 클라이언트에게 전송한다.한 번에 string 객체로 받는 방법이 없어임시 buffer로 받은 다음에 변환해주어야 한다.참고고 recv()의 리턴값은 문자열 수신에 성공할 시 그의 길이를 받게 된다. 3. 비밀번호 입력에 따른 문자열 수신받기클..
클라이언트의 코드를 분석해 본다. #include #include #include #include #include #include #include #define PORT 8080#define BUFFER_SIZE 1024int main() { int sock = 0; struct sockaddr_in serv_addr; char buffer[BUFFER_SIZE] = {0}; // 소켓 파일 디스크립터 생성 if ((sock = socket(AF_INET, SOCK_STREAM, 0)) 전체 코드이다. // 소켓 파일 디스크립터 생성 if ((sock = socket(AF_INET, SOCK_STREAM, 0)) 이 부분은 전 서버와 같이socket()을 이용해..
이번에는 연습으로 c++로 소켓 프로그램을 구현해보려 한다.c++로는 처음 구현해 보아 gpt의 힘을 빌려공부를 진행하기로 했다. 결과부터 확인을 해보면 이게 서버의 결과 이건 클라이언트의 결과이다. 서버의 코드부터 분석을 진행해본다.#include #include #include #include #include #include #include #define PORT 8080#define BUFFER_SIZE 1024using namespace std;int main() { int server_fd, new_socket; struct sockaddr_in address; int addrlen = sizeof(address); char buffer[BUFFER_SIZ..
공부해 볼 겸 개인 프로젝트를 시작해보려고 한다.멀티스레드 기반으로 클라이언트에게 파일을 전송해 주는 서버를 만들어 보려고 한다.더 나아가서 암호화 복호화를 통해 파일의 내용을 탈취할 수 없게 만드는 기능까지 넣어보려고 한다. 환경부터 세팅을 해주었다.먼저 우분투를 다운 받아준다. 그다음 vscode를 깔고 extension팩을 다운로드하여준다. gcc가 깔려있나 확인했는데 깔려있다.컴파일 및 빌드를 하려 하면 이런 오류가 나오는데 tasks 및 launch 파일을 생성해 주면 된다.근데 요즘은 자동으로 설정을 해주기 때문에 편했다. 빌드가 잘된다.
https://www.acmicpc.net/problem/9328 9328번: 열쇠 상근이는 1층 빌딩에 침입해 매우 중요한 문서를 훔쳐오려고 한다. 상근이가 가지고 있는 평면도에는 문서의 위치가 모두 나타나 있다. 빌딩의 문은 모두 잠겨있기 때문에, 문을 열려면 열쇠가 www.acmicpc.net 5 17 ***************** .............**$* *B*A*P*C**X*Y*.X. *y*x*a*p**$*$**$* ***************** cz 해당 입력을 예시로 과정을 본다. . . . . . . . . . . . . . . . . . . . . * * * * * * * * * * * * * * * * * . . . . . . . . . . . . . . . * * $ * ...
https://www.acmicpc.net/problem/2239 2239번: 스도쿠 스도쿠는 매우 간단한 숫자 퍼즐이다. 9×9 크기의 보드가 있을 때, 각 행과 각 열, 그리고 9개의 3×3 크기의 보드에 1부터 9까지의 숫자가 중복 없이 나타나도록 보드를 채우면 된다. 예를 들어 다 www.acmicpc.net 오랜만에 재밌게 푼 문제 스도쿠 빈칸을 주면 채워주면 된다. 파란색 값을 구한다고 하면 가로, 세로, 박스 안에서 겹치지 않는 숫자를 채워주어야 한다. 그럼 가능한 숫자는 여러 개이므로 이를 백트래킹으로 빈칸이 없는 스도쿠가 완성될 때까지 계속 돌려준다. #include #include #include using namespace std; vector sudoku; vector zero_po..
https://www.acmicpc.net/problem/11066 11066번: 파일 합치기 소설가인 김대전은 소설을 여러 장(chapter)으로 나누어 쓰는데, 각 장은 각각 다른 파일에 저장하곤 한다. 소설의 모든 장을 쓰고 나서는 각 장이 쓰여진 파일을 합쳐서 최종적으로 소설의 완성본 www.acmicpc.net 어려운 DP문제였다. 50 40 30 의 cost를 계산한다고 하면 (50 + 40) + (50 + 40 + 30) = 210 (40 + 30) + (50 + 40 + 30) = 190 해당 예시를 보면 꼭 전체합을 한번 더 더하는 모습을 볼 수 있다. 예시를 보면 40 30 30 50 a b c d 각 알파벳을 지정해 주며 a + b + c 라흐만 40, 30, 30을 합쳐을 때의 co..
https://www.acmicpc.net/problem/1520 1520번: 내리막 길 여행을 떠난 세준이는 지도를 하나 구하였다. 이 지도는 아래 그림과 같이 직사각형 모양이며 여러 칸으로 나뉘어져 있다. 한 칸은 한 지점을 나타내는데 각 칸에는 그 지점의 높이가 쓰여 있으 www.acmicpc.net DFS + 메모이제이션 DFS를 응용해서 중복된 길에 대한 데이터 처리 기법이다. 다음 이동할 지점이 이미 목적지에 도달할 수 있다는 데이터를 가지고 있으면 굳이 목적지까지 갈 필요가 없다. ex) 50 45 37 32 30 49 48 90 20 25 90 90 25 17 28 27 24 22 15 10 dp -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -1 -..