파이썬으로 문제를 풀다가, 다른 분들의 코드를 보면 생각보다 간결하게 짠 코드들도 많았는데요. 파이썬의 enumerate 또한 그 중 하나입니다. 이것이 어떤 함수인지 간단하게 알아보겠습니다. 먼저, 이 함수는 iterable한 것을 받고, 옵션으로 start를 받습니다. iterable 한 것 중, 대표적인 것은 list가 있는데요. 예제 프로그램을 보겠습니다. 'cho', 'ga', 'hui' 순서로 저장되어 있는 리스트가 있습니다. 뭔가 순회하는 것 처럼 보이는데요. 결과를 보겠습니다. 어? 순회해서 값을 가져올 때 마다 앞에 index가 붙음을 알 수 있어요. (0, 'cho'), (1, 'ga'), (2, 'hui')가 순서대로 나왔네요. start 값을 주면 어떻게 될까요? start에 3을 ..
레퍼런스 검색 결과
파이썬에는 any와 all이 있습니다. 최근에 배웠던 함수인데요. 간단하게 알아보겠습니다. 먼저 any 함수입니다. iterable한 것을 인풋으로 받는데요. 하나라도 참이면 true를 리턴합니다. 비어 있으면 false입니다. 예제 코드를 보겠습니다. 1번째는 list에 True가 하나 있습니다. 그리고 2번째 리스트에는 True가 없습니다. 당연하게도, any의 리턴값은 True, False가 되겠네요. 정말 그렇게 나올까요? 네. 정말 그렇게 나왔습니다. 어떠한 리스트에서 특정한 아이템들 중 하나라도 있는지를 판단할 때 꽤 유용하게 쓸 수 있습니다. 예를 들어, large에 small에 있는 원소들 중 하나라도 있는지를 테스트 하고 싶습니다. 이것을 어떻게 구현하는지 생각의 흐름을 보도록 할게요. ..
자바에서 map이나 set에 특정한 원소들이 모두 있는지 확인하려면 어떻게 해야 할까요? stream을 생각하기 쉽지만, 사실 map이나 set에서는 containsAll을 쓰는 게 나을 수도 있습니다. containsAll은 collection이 c에 있는 모든 원소들을 가지고 있는지를 판단합니다. 보통 stream의 allMatch나, filter를 이용해서 처리하기도 할 텐데요. 저는 containsAll 메소드를 쓰는 것을 보다 선호합니다. 더 직관적이기 때문입니다. 사용법을 간단하게 보겠습니다. ori와 tar에 1부터 10까지 키를 넣었습니다. 그러면 처음에 둘 다 1부터 10까지 들어있을 테니, ori가 tar에 있는 원소들을 모두 가지고 있는 것이 맞습니다. 문제는, ori에서 5를 제거했..
제 코딩테스트 레포가 업데이트 되었습니다. stream 관련한 것도 있었고, 굳이 리스트 안에 있는 원소 갯수를 세는데 리스트 컴프리헨션에 len을 섞을 필요가 있냐는 피드백도 받았기 때문입니다. 예제 프로그램을 보겠습니다. 제 예전 21771번 풀이 코드는 요런 식이였습니다. 변경 이력을 봐도 알 수 있습니다. 무엇을 하는 것이냐면, 리스트 lt에서 k가 1인 것만 filtering을 해서 새로운 리스트를 만들고, 그 리스트에 있는 원소의 수를 세서 1의 갯수를 세는 것입니다. 결과는 3이 나옵니다. 의도한 대로 나왔으니 틀린 것은 아닙니다만, 문득 의문이 듭니다. 리스트 안에서 1의 개수를 세기 위해서 논리적으로 저렇게 많은 일이 필요할까요? 이 부분은 사실 잘 모르겠습니다. 대신에, 리스트에 있는 ..
문제 출제 작업을 할 때, 데이터를 random하게 생성하는 것은 매우 중요한 일 중 하나입니다. 제가 출제한 코딩테스트 문제들은 생각보다 제약 조건이 단순하지 않아서 choices에 weights 인자를 넣어서 생성할 일은 거의 없었습니다. 그런데, 나중에 출제를 할 때 알아두면 좋을 듯 해서 정리하게 되었습니다. 옛날에 문제를 출제했을 때, A, B, C 쿼리가 일정 비율로 나오게끔 generate하는 코드도 꽤 제작했던 걸 보면, 안 필요할 거 같지는 않기 때문입니다. list에 count는 리스트 내에서 value가 출현한 횟수를 세어줍니다. 예제에서는 이 함수를 많이 쓰니, 미리 언급하고 넘어가겠습니다. 기본적으로, choices는 복원 추출을 하게 됩니다. 같은 원소를 여러 번 뽑는 것이 가능..
최근댓글