[AIOHTTP]AIOHTTP 란?
·
SW개발/IT 용어
AIOHTTP 란? aiohttp는 Python 3.4 부터 표준 라이브러리로 추가된 asyncio를 위한 HTTP 서버/클라이언트 프레임워크이다. aiohttp 의 다양한 기능 Client / Server API Persistent connections Websockets 자세한 것은 공식사이트에서 확인할 수 있다.
[WebRTC]WebRTC란?
·
SW개발/IT 용어
WebRTC 란? Web Real-Time Commnunication 의 약자 웹 어플리케이션(Android 및 IOS 지원) 및 사이트들이 별도의 소프트웨어 없이 음성, 영상, 파일 같은 데이터를 브라우저끼리 주고 받을 수 있게 만든 기술 WebRTC로 구성된 프로그램들은 별도의 플러그인이나 소프트웨어 없이 데이터 공유가 가능하다. WebRTC 통신 원리 WebRTC 기술은 P2P 통신에 최적화가 되어 있음 WebRTC 에 사용되는 기술은 여러 가지가 있지만 크게 3가지의 클래스에 의해 실시간 데이터 교환이 이루어짐 MediaStream - 카메라와 마이크 등의 데이터 스트림 접근 RTCPeerConnection - 암호화 및 대역폭 관리 및 오디오, 비디오의 연결 RTCDataChannel - 일반적..
[백준]10773번 제로 - 스택
·
SW개발/코딩테스트
import sys n = int(sys.stdin.readline()) stk = [] for i in range(n): value = int(sys.stdin.readline()) if(value == 0): stk.pop() else: stk.append(value) print(sum(stk)) 코드 설명 먼저 반복할 횟수를 n 이라는 변수에 저장 후 빈 리스트를 생성한다. 값을 입력 받으면서 그 값이 0이라면 저장하지 않고, pop() 연산을 통해 이전에 받은 값을 지운다. 0이 아닐 경우에는 저장한다. sum() 함수를 이용하여 스택의 합을 출력한다. Point : 0일 경우에는 저장 대신 삭제 기능을 구현한다.
[Flask]Hello world!
·
SW개발/Flask
Flask의 가장 큰 특징은 역시 "마이크로"프레임워크라는 점이다. 이 점은 공식 홈페이지에서도 강조하고 있기 때문에 웹 프로그램을 통해 "Hello World"를 출력하는 것도 역시 어렵지 않게 할 수 있다. Flask 공식 Documentaion Flask로 Hello World! 일단 플라스크로 프로젝트를 구성할 폴더에 파이썬 가상환경을 만들고, 플라스크를 설치한다. 플라스크의 설치 pip install Flask 그리고 프로젝트 안에 app.py 라는 스크립트 파일을 만들어(Pycharm의 Flask 프로젝트 생성 시 이미 만들어져 있음) 다음과 같은 코드를 넣고 실행하면 웹 프로그램을 볼 수 있다. from flask import Flask app = Flask(__name__) @app.rou..
[Flask]Flask란?
·
SW개발/Flask
Flask란 ? 플라스크는 파이썬으로 작성된 마이크로 웹 프레임 워크의 하나이다. Flask의 특징 플라스크는 마이크로 웹 프레임워크다. 즉 간결하게 유지하고 확장할 수 있음을 의미한다. 간결하다는 것은? -> 짧은 코드만으로도 완벽히 동작하는 웹 프로그램을 만들 수 있다. 확장성 있는 설계? -> 플라스크에는 다양한 확장 모듈을 통해 입맛대로 만들 수 있다. 나는 두 가지의 프레임워크를 모두 사용해본 경험이 있다. 경험을 빌어서 차이점을 얘기해 보고자 한다. Flask vs Django 플라스크는 자유로운 프레임워크다. 그에 반해 장고는 모든 기능을 지원하는 프레임워크다. 장고는 매우 많은 기능들을 자체적으로 가지고 있고, 개발자는 그 규칙에 맞추어 코딩하여야 한다. 플라스크는 기능들을 확장 모듈들을 ..
[백준]10828번 스택 - 스택
·
SW개발/코딩테스트
import sys a = int(sys.stdin.readline()) stk = [] for i in range(a) : command = sys.stdin.readline().strip() if(command.split()[0] == 'push'): stk.append(int(command.split()[1])) elif(command == 'pop'): if len(stk) > 0: print(stk.pop()) else : print(-1) elif(command == 'size'): print(len(stk)) elif(command == 'empty'): if len(stk) == 0 : print(1) else : print(0) elif(command == 'top'): if len(st..
[백준]1541번 잃어버린 괄호 - 그리디
·
SW개발/코딩테스트
a = input().split('-') sum = 0 for i in a[0].split('+'): sum += int(i) for i in a[1:]: for j in i.split('+'): sum -= int(j) print(sum) 코드 설명 먼저 -를 기준으로 문자열을 분리시켜 저장한다. 그 후, 리스트의 첫번째 원소에 있는 숫자들을 더해주기 위해 + 로 분리하고 그 값을 더해준다. 그 다음 리스트의 두번째 원소부터 +로 모두 분리시켜 준 뒤, 그 값을 모두 뺄셈하여준다. Point : 해당 수식에서 -를 만나면 다음 -가 나오기 전까지는 모두 뺄셈을 해주면 최솟값을 만들 수 있다. 따라서, -로 문자열을 분리 시킨 후 분리되어 있는 값들은 + 이므로 수들을 더하여 준 후, 그 더한 수를 뺄셈..
[백준]11399번 ATM - 그리디
·
SW개발/코딩테스트
n = int(input()) sum = 0 result = 0 a = list(map(int, input().split())) a.sort() for j in range(n): sum += a[j] result += sum print(result) 코드 설명 먼저 각 사람이 돈을 인출하는데 필요한 시간을 a 라는 리스트에 저장한 후 정렬을 해준다. 그 후 n 만큼 반복문을 돌리면서 sum 이라는 변수에 각 사람당 걸리는 시간을 구하고 누적 시간을 구하기 위해 result 변수에 덧셈해준다. Point : 각 상황에서 가장 최소의 시간이 걸리게 하는 것이 그리디 알고리즘이 되므로, sort() 함수를 통하여 정렬을 해준다. 그 후 누적시간을 구해야 하기 때문에 sum -> 각 사람이 걸리는 시간, res..
[백준]1931번 회의실 배정 - 그리디
·
SW개발/코딩테스트
n = int(input()) a = [[1]*2 for i in range(n)] cnt = 0 check = 0 for i in range(n): a[i][0], a[i][1] = map(int, input().split()) a.sort(key=lambda x:(x[1], x[0])) for i in range(n): if a[i][0] >= check: cnt += 1 check = a[i][1] print(cnt) 코드 설명 먼저 회의의 수를 위한 n, 회의의 정보를 위한 a 리스트, 회의의 최대 개수를 위한 cnt, 끝나는 시간을 체크하기 위한 check 변수를 선언한다. 그 후 회의 수 만큼 반복문을 통해 a 리스트에 회의의 정보를 전부 할당한 후, 정렬 함수를 통하여(lambda 사용) 끝..
[백준]11047번 동전 0 - 그리디
·
SW개발/코딩테스트
import math n, k = map(int,input().split()) a = [] cnt = 0 for i in range(n): a.append(int(input())) for i in range(len(a)-1, -1, -1): if k < a[i] : continue cnt = cnt + int(k / a[i]) k = k % a[i] if k == 0: break print(cnt) 코드 설명 먼저, 입력 개수와 계산하려는 값을 map 함수를 이용하여 n, k 변수에 저장한다. 그 후 빈 리스트와 카운트를 위한 변수를 선언하고 n의 수만큼 반복문을 통해 동전의 가치를 입력받고 리스트에 저장한다. 저장된 리스트는 가장 큰 동전의 가치가 맨 뒤에 있으므로 리스트의 뒤부터 판단하여 동전의 가치..