[DAY 14] 백준 2033번 - 반올림
·
Algorithm/항해일지 TIL
문제https://www.acmicpc.net/problem/2033 1. 문제 설명10의 자리 숫자이면 1의 자리에서 반올림100의 자리 숫자이면 10의 자리에서 반올림처음 생각한 코드def round_number(n): if n  > 이걸 보니까 ... 문제를 이해하는 게 제일 중요하다고 생각했다 ㅠㅠ일단 정말 정말 간단한 문제라고 생각했고 그냥 길이에 맞춰서 반올림하면 되는거 아닌가?? 라고 생각했는데 계속 ~~틀리는거다..하정말 답답했음 ㅠㅠ 내가 간과했던 것은-> 반복문을 사용하지 않음 -> 다음 자리수로 넘어가지 않음-> 조건에 해당하는지를 검토하지 않음.. 이정도가 될 것 같다. ㅠㅠ  코드 자체는 복잡하지 않은데 문제를 이해하는데 꽤나 오랜시간이 걸렸다.. ㅠ ㅁ ㅠ  제출한 코드N ..
[DAY 13] 프로그래머스 가운데 글자 가져오기 / 슬라이싱
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/12903 1. 코드 설명 두글자 반환하기=> 가운데 앞뒤글자라고 생각하기 글자 수가 짝수와 홀수일때 글자수 나누기 두글자 인덱싱하기 2. 핵심 내용 슬라이싱 : 시퀀스 데이터의 특정 범위를 지정하여 해당 범위에 있는 요소들을 가져올 수 있음 s = "Hello, World!" print(s[0:5]) # "Hello" print(s[7:12]) # "World" print(s[:5]) # "Hello" (start를 생략하면 처음부터 시작) print(s[7:]) # "World!" (stop을 생략하면 끝까지) print(s[::2]) # "Hlo ol!" (step을 2로 지정하여 홀수 인덱..
[DAY 12] 프로그래머스 k번째 수 / 배열 인덱스
·
카테고리 없음
문제 https://school.programmers.co.kr/learn/courses/30/lessons/42748 1. 코드 설명 인덱스는 맨 처음이 0 부터 시작이다 => 이부분을 처리하는 게 조금 헷갈렸다. ㅠㅠ 세개의 인자를 어떻게 처리할 것인가?? 2. 코드 실행 def solution(array, commands): answer = [] for command in commands: i, j, k = command cut = sorted(array[i-1:j]) answer.append(cut[k-1]) return answer 처음에 0부터 시작인데 얘는 1로 인식하니까 +1 이라고 했다가 계속해서 오류가 났다. 내가 잘못 이해한 부분이다.ㅜ 나머지는 다 맞았는데 +1 에서 계속 틀렸던 거..
[DAY 11] 프로그래머스 없는 숫자 더하기
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/86051 1. 코드 설명 없는 숫자 더하기 = > 정답의 리스트를 주고 그 리스트에 없으면 없는 숫자이므로 빈 리스트에 더해주면 되지 않을까? 2. 코드 실행 // 첫번째 시도 def solution(numbers): total = 0 find = [0,1,2,3,4,5,6,7,8,9] for i in find: if i not in numbers: total += i return total 그런데 생각해보니... 0부터 9까지 이면 굳이 리스트로 만들지 않아도 된다는 게 번뜩 생각났다. -_ - // 두번째 시도 def solution(numbers): total = 0 for i in ran..
[DAY 10] 프로그래머스 평균 구하기 / SUM
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/12944 1. 코드 설명 평균 구하는 법 = 각 숫자 다 더하기 / 각 숫자 갯수 2. 중요한 개념 ※ SUM --> 리스트나 튜플 처럼 인덱스 내에서 순환, 접근이 가능한 자료형이여야 하고 내부에 숫자로만 이루어져 있어야 한다. --> 결과값: 인자로 들어온 내부의 모든 요소의 합 3. 코드 실행 // 첫번째 시도 def solution(arr): s = 0 for i in arr: s += i total = s / len(arr) return total 처음엔 이렇게 엄청 간단하게 생각했다. 물론 틀린 코드는 아니지만 조금 더 쉬운 코드가 없을까.. 하다가 sum 이 생각났따 ㅠ.ㅠ // 두..
[DAY 9] 프로그래머스 문자열 내 마음대로 정렬하기 / lambda
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/12915 항해 미들러문제!! ㅎㅎ 1. 코드 설명 인덱스 입력받기 인덱스 별로 오름차순 정렬 2. 코드 실행 def solution(strings, n): return sorted(strings, key=lambda x: (x[n], x)) 3. 중요한 개념 ※ lambda 란?? -> 함수를 간결하게 만들기 위한 익명함수를 만들 때 사용되는 함수 기본적인 구조 ) lambda 매개변수: 표현식 -> 이때 매개변수들은 함수에 전달되는 입력 값이고, 표현식은 해당 변수의 반환값이다. 예를 들어 두 수를 더하는 함수를 람다함수로 표현하면 add = lambda x,y : x+ y 가 된다. -> 변..
[DAY 9] 프로그래머스 LV1. 짝수와 홀수
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/12937 1. 코드 설명 짝수이면 (0도 포함) even 반환 홀수이면 odd 반환 2. 코드 실행 def solution(num): if num ==0 or num % 2 ==0: return "Even" else: return "Odd" 3. 결과 솔직히...3초만에 풀었다 ㅋㅋㅋ헛..
[DAY 8] 프로그래머스 LV1. 하샤드 수
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/12947 1. 코드 설명 각 자릿수의 합 더하기 딱 떨어진다 = 나머지가 0이다. 2. 코드 실행 2-1. 각 자릿수의 합 더하기 코드 -> 각 자릿수를 하나씩 꺼내기 위해 x를 문자열로 바꾸고, 자릿수의 합을 하나씩 더한 아이들을 number에 담는다. 이때 문자열로 받은 각 자리를 더하기 위해 int 정수형으로 바꿔주었다. for i in str(x): # 각 자릿수를 꺼내기 위해 입력받은 수를 한자리씩 문자열로 바꿔줌 number+=int(i) #number에 각 자릿수의 합을 더함 #그런데 이때 문자열로 더해주면 안되니까 다시 정수형으로 바꿔줌 2-2. 전체코드 def solution(x..
[DAY 7] 프로그래머스 LV1. 행렬의 덧셈
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/12950 1. 코드 설명 반복문을 행렬의 모든 행에 대해 수행해야함 행렬의 행의 개수를 확인하고 각 원소의 값을 더해주는 반복문 2. 코드 실행 // 첫번째 시도 def solution(arr1, arr2): answer=[] for i in range(len(arr1)): for j in range(len(arr1[0])): row= [arr1[i][j] + arr2[i][j]] answer.append(row) return answer > 이러한 결과값이 나왔다. ㅠㅠ 그러니까 내가 각 원소의 값은 더할 수 있는데 한 개의 리스트로 값을 반환하지 못하니까 행렬로 인식하지 못하고 그냥 원소끼리..
[DAY 6] 프로그래머스 LV1. 음양 더하기
·
Algorithm/항해일지 TIL
문제 https://school.programmers.co.kr/learn/courses/30/lessons/76501 1. 코드 풀이 배열 두개라는 거에 쫄 필요가 없다 ㅠ 그냥 TRUE면 양수, FALSE는 음수라는 것을 생각하면 되고 각자 계속 더해주기만 하면 된다. 2. 코드 실행 def solution(absolutes, signs): answer = 0 for i in range(len(absolutes)): if signs[i] == True: answer += absolutes[i] else: answer -= absolutes[i] return answer 더보기 *len(absolute)에 대하여 * 처음에 len 을 하지 못해서 계속해서 코드 오류가 났다 ㅠㅠ 그래서 이 부분은 꼭 챙..
하이롱하이롱
'항해일지' 태그의 글 목록