알고리즘 풀면서 JS로 풀때처럼 문자열에서 특정 인덱스의 문자를 변경하려고 했으나 에러가 발생했다. TypeError: 'str' object does not support item assignment. 이유 파이썬의 문자열은 튜플 자료형과 같이 immutable해서 변환할 수 없다. 그래서 다른 방법을 사용해야한다. 1. list 자료형으로 변환하여 사용한다. 2. replace()를 사용한다. 3. 새로운 변수를 만들어 사용한다. 나는 list를 이용해서 문제를 해결했다. 참고 1 참고 2
프로그램을 측정할 때 - 하드웨어와 소프트웨어 환경이 상이 - 다양한 크기의 입력이 존재 이런 것들에 영향을 받지 않고 객관적으로 알고리즘이 어느 정도 성능을 보이는지 측정하고 비교하는 방법을 필요로 하게 되었다. 객관적인 측정을 위해 가상컴퓨터(RAM) + 가상언어 + 가상코드의 조건에서 성능을 측정한다. 가상컴퓨터(RAM) 기본 연산이 1단위 시간내에 수행된다고 정의한 가상의 컴퓨터 기본연산 배정연산, 대입연산, 복사연산 : a = b 산술연산 : +, -, *, /, % 등 비교연산 : =, ==, != 논리연산 : and, or, not 비트연산 : bit별 and, or, not 가상언어 가상컴퓨터 위에서 돌아가는 언어, 아래와 같은 사항을 만족하는 가상의 언어 기본연산을 표현할 수 있어야한다...
강의를 들으며 import와 패키지를 배우던 중에 현재경로(.)와 상대경로(..)가 파이썬에도 똑같다고 해서 그렇게 경로를 적어줬는데 에러가 발생했다. 상위 경로도 import 하고 싶어서 해보는데 똑같은 에러가 발생했다. from .ch_test.ch16_test import ch16_test from ..playground import 별찍기 ImportError: attempted relative import with no known parent package 이유 자바스크립트에서는 경로의 시작을 '.'로 해도 되는데 파이썬에서는 안 되는 것 같다. 현재 파일의 하위 경로에 있는 폴더는 이름부터 시작하도록해서 접근했고 상위경로는 일단 sys.path를 추가하는 것으로 해결했다. import sys ..
알고리즘을 풀 때 자주 최대공약수가 필요한 경우가 생겼다. 최대공약수를 사용해 풀었던 문제 프로그래머스 레벨 0 / 분수의 덧셈 프로그래머스 레벨 0 / 유한소수 판별하기 프로그래머스 레벨 1 / 최대공약수와 최소공배수 여러 번 최대공약수를 구해야 하는 문제를 풀었는데도 매번 기억이 안 나서 까먹을 때마다 보려고 기록해 둔다. 최대공약수 유클리드 호제법 최대공약수는 유클리드 호제법을 이용하면 구할 수 있다. 두 개의 숫자가 있을 때 x를 y로 나누었을 때 나머지(r)가 0이면 y는 이 두 수의 최소공배수가 된다. 나머지가 0이 될 때까지 값을 앞으로 당겨가며 계속 반복하면 된다. while문을 사용해서 표현했을 때 최소공배수가 구해진 시점(r이 0일때)에 y가 r이 되면 0이 되므로 종료된다. 하지만 그..
얼마 전에 1월 동안 운영했던 올해까치를 서비스 종료했다. 리팩토링 막 배포했을 때는 긴 이미지 로딩으로 사용자 경험이 좋지 않았다. 프론트 assets/images 폴더에 이미지를 직접 넣어서 로딩하도록 했는데 같은 이미지인데도 웹에 업로드한 url로 가져오는 것이 로딩이 더 빨랐다. (이 부분에 대해서는 이유를 찾아봐야 할 것 같다.) 수정했어도 여전히 기대하던 속도보다 느려서 레이지 로딩을 적용하기로 했다. react progressive graceful image라는 라이브러리를 사용해 이미지가 완벽히 로딩되기 전에는 저용량의 placeholder를 보여주고 로딩이 완료되면 본 이미지를 보여주도록 했다. 기존 이미지는 아무리 줄여도 용량이 작아지지 않아서 디자이너님께 작은 사이즈의 이미지를 별도로..
SSL의 동작방식 SSL은 암호화된 데이터를 전송하기 위해 공개키와 대칭키를 혼합하여 사용한다. 실제 데이터 : 대칭키 대칭키의 키 : 공개키 악수 -> 전송(세션) -> 세션종료 1. 악수 브라우저와 서버는 서로 상대방이 존재하는지, 상대방과 데이터를 주고받기 위해서는 어떤 방법을 사용해야 하는지를 파악한다. 서버의 인증서를 클라이언트에게 전송, 클라이언트&서버가 서로 처리할 수 있는 암호화 기법을 교환한다. 1. 클라이언트 측에서 생성한 랜덤 데이터로 클라이언트가 지원하는 암호화 방식들과 세션 아이디를 서버로 전달한다. (Client Hello) 2. 서버 측에서 생성한 랜덤 데이터와 클라이언트가 전달한 암호화 방식 중에서 서버 쪽에서도 사용할 수 있는 암호화 방식을 선택해서 인증서와 함께 클라이언트..
리코일 공식 문서가 시키는 데로 RecoilRoot로 감싸줬는데 에러가 발생했다. this component must be used inside a component. 이유 최상위 루트가 아니고 중간 라우터 파일에서 감싸줬더니 에러가 발생했다. 그래서 최상위에 감싸줬더니 해결됐다. ReactDOM.createRoot(document.getElementById('root') as HTMLElement).render( , ); 참고
- Total
- Today
- Yesterday
- 구름에듀
- 제이쿼리
- TS
- vscode
- javascript
- map
- 김버그
- React
- 회고
- 스파르타코딩클럽
- scss
- 파이썬
- 제로초
- 드림코딩
- 깃
- 비주얼스튜디오코드
- Til
- 코드잇
- Python
- CSS
- 리액트
- js
- Typescript
- 코딩앙마
- 타입스크립트
- html
- 자바스크립트
- git
- 저스트코드
- vue
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | |||
5 | 6 | 7 | 8 | 9 | 10 | 11 |
12 | 13 | 14 | 15 | 16 | 17 | 18 |
19 | 20 | 21 | 22 | 23 | 24 | 25 |
26 | 27 | 28 | 29 | 30 | 31 |