def solution(absolutes, signs): answer = 0 for i in range(len(absolutes)): if signs[i]: answer += absolutes[i] else: answer -= absolutes[i] return answer 인덱스 0부터 len(absolutes)-1까지 하나씩 접근하면서 양이면 더해주고 음이면 빼준다. => 한 줄이면 끝나는 풀이인데 좀 길게한 느낌도 있다. 너무 짧은 코드도 읽기 어렵다면 좋은 건 아니지만.. 새로운 도구들도 많이 사용해봐야겠다. zip같은 것도 많이 사용해보구
분류 전체보기
def solution(numbers): return sum(range(10)) - sum(numbers) 완전 간결하다. 어차피 합을 구하는 거니까 이게 제일 베스트일 것 같다. solution = lambda x: sum(range(10)) - sum(x) 람다로 더더 줄여버렸다. def solution(numbers): return sum([i for i in range(10) if i not in numbers]) 문제를 그대로 넣어버린 코드다. 의도가 한눈에 보인다. 멋있다.
def solution(numbers): answer = 0 allNum = [0,1,2,3,4,5,6,7,8,9] for n in numbers: allNum.remove(n) for n in allNum: answer += n return answer ■ 사용 변수: allNum(0~9까지의 숫자가 저장된 리스트) 1. numbers에 저장된 변수를 allNum에서 remove해준다 2. 남은 수들을 각각 더해준다. => 파이썬에 sum함수가 있다는 걸 까먹었다. 문제를 풀고난 후 더 좋은 풀이가 없을지 고민하는 과정을 자꾸 까먹는다. 문제를 풀었다고 좋아하지말고 다른 방법도 생각해보자 좀
def solution(board, moves): answer = 0 stack = [0] for m in moves: for i in range(len(board)): if (board[i][m-1] != 0): stack.append(board[i][m-1]) board[i][m-1] = 0 if (stack[-1] == stack[-2]): stack.pop() stack.pop() answer += 2 break return answer 간결하다. stack에 0을 넣어놓고 시작하여 stack[-2]가 없는 경우를 고려하지 않아도 되는 것도 참신한 방법인 것 같다. 굳이 -1을 빼서 비교해볼 필요도 없고 좋은 것 같다. def solution(board, moves): cols = list(map..
def isEmpty(stack): return (len(stack) == 0) def solution(board, moves): answer = 0 b_stack = {} stack = [] height = len(board) width = len(board[0]) for w in range(width): tmp = [] for h in range(height-1, -1, -1): if (board[h][w] == 0): break else: tmp.append(board[h][w]) b_stack[w+1] = tmp for m in moves: if (not isEmpty(b_stack[m])): item = b_stack[m].pop() if (not isEmpty(stack) and stack[-..
1~45숫자 6개의 숫자 고르기 6개:1등/ 5개:2등/ 4개:3등/ ... / 2개: 5등/ 1개:6등/ 0개:6등 0은 맞출 수도 있고 못맞출 수도 있다. def solution(lottos, win_nums): rank = [6,6,5,4,3,2,1] cnt_0 = lottos.count(0) # 0 개수 세기 ans = 0 for x in win_nums: if x in lottos: ans += 1 return rank[cnt_0+ans], rank[ans] print(solution([1,2,3,4,0,0], [1,2,3,4,5,6])) 랭크를 저렇게 배열 인덱스로 고를 수 있도록 하는 것도 매력적인 방법인 것 같다. 보기도 쉽고 말이다. def solution(lottos, win_nums)..
파이썬에서 반올림은 round함수를 사용합니다. round - 파이썬의 내장함수(import 필요x) - 두 번째 매개변수로 반올림 자릿수 결정가능 ex) round(1.5555, 2) = 1.56 # 두 번째 자리까지 표시 - 대부분의 경우 일반적으로 생각하는 반올림기능 수행 - 1.5, 2.5, 3.5 경우 자신과 가장 가까운 짝수 반환 ◼︎ 일반적인 반올림 기능 ◼︎ .5 경우 자신과 가장 가까운 짝수 반환 일반적으로 0.5 반올림은 1이라고 생각하실텐데, 파이썬 round함수는 0을 반환합니다. 여기서도 마찬가지로 1.57을 원했는데 1.56이 나와버립니다. 1) 정수부분이 짝수일 경우 0.1을 더하여 round함수 사용 원래 round(0.5) = 0 인데 1이 나옵니다. 조금 더 일반화 하면 ..
Q. 3번째 자리에서 반올림 하고싶다! 1. round함수 public static long round(double a) round는 소수점 첫 째 자리에서 반올림하여 정수값을 반환해준다. 3번째 자리에서 반올림 하고싶다면 1) 원하는 값에 100을 곱한 뒤 2) 그 값을 round함수에 넣어주고 3) 거기에 100을 나눠주면 된다. 이 때 반환값이 long 정수라는 것에 주의하여 형변환 잘해주자. 2. String.format("%.2f", num) 하고 float으로 형변환 %.2f를 이용해주면 소수점 2번째자리까지 표현된 String값이 나온다. (3번째 자리에서 반올림됨) 이걸 float값으로 받고싶다면 Float.parseFloat() 함수에 집어넣어주면 된다. 3. 곱하고 0.5더해서 int..
import java.util.*; public class prac { static void putWord(HashMap words) { words.put("chair", "의자"); words.put("computer", "컴퓨터"); words.put("Integer", "정수"); } public static void main(String[] args) { HashMap words = new HashMap(); Scanner scanner = new Scanner(System.in); putWord(words); Set keys = words.keySet(); Iterator engWords = keys.iterator(); int i = 0; int right = 0; while (engWords..
보기싫은 책 목록이다. 앞에 10213 이런 숫자들이랑 뒤에 붙은 1이나 2는 쓸모없는 숫자처럼 보인다. 탭 키도 엉망이라 보기 좋지 않다. 하나하나 수정하기는 귀찮으니 프로그램으로 만들어줄 생각이다. 먼저 결과 화면부터 보자. 출판사랑 책이름이 붙어있기는 하지만 아까보다는 보기 좋은 문서같다. public static void main(String[] args) { Vector all = new Vector(); inputDocument(all); scan_and_print(all); } main함수는 간단하게 만들어줬다. all백터에 문서 전체를 받고 scan_and_print함수로 정리된 문서를 출력할거다. static boolean isNo(String str) { // 앞에 10215 이거인지 ..