250x250
Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- position
- venv
- A태그
- 함수실행시간
- itertools
- iterable
- Level1
- with\
- 함수성능평가
- 내일배움캠프
- 데벨챌
- 프로그래머스
- vscode
- googleappscript
- 가상환경
- time()
- cte
- 데이터리안
- gitignore
- WIL
- 알고리즘
- googlesheet
- 데이터넥스트레벨챌린지
- Iterator
- AI 5기
- 우선순위
- Display
- python
- 그로스해킹
- git #github #내일배움캠프
Archives
- Today
- Total
05의 개발 계발
[페어프로그래밍] 230517 신고 결과 받기 Lv.1 | set split dict 본문
728x90
페어프로그래밍 결과 코드
'''
1. 각 유저는 한 번에 한 명의 유저를 신고할 수 있습니다.
-신고 횟수에 제한은 없습니다. 서로 다른 유저를 계속해서 신고할 수 있습니다.
-한 유저를 여러 번 신고할 수도 있지만, 동일한 유저에 대한 신고 횟수는 1회로 처리됩니다.
2. k번 이상 신고된 유저는 게시판 이용이 정지되며, 해당 유저를 신고한 모든 유저에게 정지 사실을 메일로 발송합니다.
-유저가 신고한 모든 내용을 취합하여 마지막에 한꺼번에 게시판 이용 정지를 시키면서 정지 메일을 발송합니다.
output : <list> 각 유저별로 처리 결과 메일을 받은 횟수
'''
# <1> 각 회원마다 신고한 유저의 이름을 파악, 누가 누구를 신고했을까! → key:value {신고자:피신고자}
# <2> 회원중에 신고횟수가 정지 수준에 도달한 유저의 명단
# <3> 각 회원마다 신고한 유저 중 정지된 유저의 명단
# <4> <3>번의 유저의 수를 카운트해서 list에 담아서 return하면 정답!
# 페어프로그래밍으로 제작한 코드
def solution(id_list, report, k):
note={}
banner=[]
for i in set(report):
a=i.split(" ")
try:
note[a[0]] += [a[1]]
except:
note[a[0]] = [a[1]]
banner.append(a[1])
print(note)
print(banner)
ban_report={} #신고당한 횟수를 저장할 딕셔너리
for i in id_list:
ban_report[i]=0
for ban in banner:
ban_report[ban] +=1 #신고당한 횟수 카운트
print(ban_report)
pause=[] # 정지대상을 저장할 리스트
for i in id_list:
if ban_report[i] >= k:
pause.append(i)
print(pause)
for i in id_list:
ban_report[i]=0
for key,value in note.items(): # 신고자: 피신고자 명단
for i in pause:
if i in value:
ban_report[key] +=1
answer = list(ban_report.values())
return answer
+전체 테스트용 코드
더보기
import os
os.system("cls")
# https://school.programmers.co.kr/learn/courses/30/lessons/92334
'''
1. 각 유저는 한 번에 한 명의 유저를 신고할 수 있습니다.
-신고 횟수에 제한은 없습니다. 서로 다른 유저를 계속해서 신고할 수 있습니다.
-한 유저를 여러 번 신고할 수도 있지만, 동일한 유저에 대한 신고 횟수는 1회로 처리됩니다.
2. k번 이상 신고된 유저는 게시판 이용이 정지되며, 해당 유저를 신고한 모든 유저에게 정지 사실을 메일로 발송합니다.
-유저가 신고한 모든 내용을 취합하여 마지막에 한꺼번에 게시판 이용 정지를 시키면서 정지 메일을 발송합니다.
output : <list> 각 유저별로 처리 결과 메일을 받은 횟수
'''
# <1> 각 회원마다 신고한 유저의 이름을 파악, 누가 누구를 신고했을까! → key:value {신고자:피신고자}
# <2> 회원중에 신고횟수가 정지 수준에 도달한 유저의 명단
# <3> 각 회원마다 신고한 유저 중 정지된 유저의 명단
# <4> <3>번의 유저의 수를 카운트해서 list에 담아서 return하면 정답!
# ====================코딩 영역========================
def solution(id_list, report, k):
note={}
banner=[]
for i in set(report):
a=i.split(" ")
try:
note[a[0]] += [a[1]]
except:
note[a[0]] = [a[1]]
banner.append(a[1])
print(note)
print(banner)
ban_report={} #신고당한 횟수를 저장할 딕셔너리
for i in id_list:
ban_report[i]=0
for ban in banner:
ban_report[ban] +=1 #신고당한 횟수 카운트
print(ban_report)
pause=[] # 정지대상을 저장할 리스트
for i in id_list:
if ban_report[i] >= k:
pause.append(i)
print(pause)
for i in id_list:
ban_report[i]=0
for key,value in note.items(): # 신고자: 피신고자 명단
for i in pause:
if i in value:
ban_report[key] +=1
answer = list(ban_report.values())
return answer
# ====================리팩토링 영역========================
def solution(id_list, report, k):
report = set(report) # 중복된 신고 무시
ban_report={} #신고자 매칭
ban_count={} #신고당한 횟수
result={} #유저당 이메일 수신 횟수를 담을 딕셔너리
for i in id_list:
ban_report[i]=[]
ban_count[i]=0
result[i]=0
for i in report:
a=i.split(" ")
ban_report[a[0]] += [a[1]]
ban_count[a[1]] += 1
pause=[] # 정지대상을 저장할 리스트
for key,value in ban_count.items():
if value >= k: # 신고당한 횟수가 기준치 k를 넘긴다면 정지명단에 추가
pause.append(key)
for key,value in ban_report.items(): # 신고자: 피신고자 명단
for i in pause:
if i in value:
result[key] +=1
answer = list(result.values())
return answer
# ====================테스트 영역========================
id_list = ["muzi", "frodo", "apeach", "neo"]
report = ["muzi frodo","apeach frodo","frodo neo","muzi neo","apeach muzi"]
k = 2
id_list1 = ["con", "ryan"]
report1 = ["ryan con", "ryan con", "ryan con", "ryan con"]
k1 = 3
print("[2,1,1,0] ▶ ",solution(id_list, report, k))
print("\n")
print("[0,0] ▶ ",solution(id_list1, report1, k1))
리팩토링 코드
# ====================리팩토링 영역========================
def solution(id_list, report, k):
report = set(report) # 중복된 신고 무시
ban_report={} #신고자 매칭
ban_count={} #신고당한 횟수
result={} #유저당 이메일 수신 횟수를 담을 딕셔너리
for i in id_list:
ban_report[i]=[]
ban_count[i]=0
result[i]=0
for i in report:
a=i.split(" ")
ban_report[a[0]] += [a[1]]
ban_count[a[1]] += 1
pause=[] # 정지대상을 저장할 리스트
for key,value in ban_count.items():
if value >= k: # 신고당한 횟수가 기준치 k를 넘긴다면 정지명단에 추가
pause.append(key)
for key,value in ban_report.items(): # 신고자: 피신고자 명단
for i in pause:
if i in value:
result[key] +=1
answer = list(result.values())
return answer
흠터레스팅 코드
# 1번 | 컴프리헨션 , 인덱싱
def solution(id_list, report, k):
answer = [0] * len(id_list)
reports = {x : 0 for x in id_list}
for r in set(report):
reports[r.split()[1]] += 1
for r in set(report):
if reports[r.split()[1]] >= k:
answer[id_list.index(r.split()[0])] += 1
return answer
시사점 or 새로이 알게된 점
컴프리헨싱&인덱싱 활용
answer = [0] * len(id_list)
# for문 대신 0을 부여한 빈 리스트를 선언 → 시간복잡도에서 효율↑
reports = {x : 0 for x in id_list}
# 컴프리헨션으로 <list> → <dict>으로 바로 변환
answer[id_list.index(r.split()[0])] += 1
# index를 활용해 dict같은 효과를 구현
728x90
'내일배움캠프 AI > 페어프로그래밍' 카테고리의 다른 글
[페어프로그래밍] 230518 숫자 문자열과 영단어 Lv.1 | list replace (0) | 2023.05.18 |
---|---|
[페어프로그래밍] 230518 소수찾기 Lv.1 | for if range (0) | 2023.05.18 |
[페어프로그래밍] 230516 신규아이디추천_Lv.1 | replace() , [:] 슬라이싱 (0) | 2023.05.16 |
[페어프로그래밍] 230503 둘만의 암호 (0) | 2023.05.03 |
[페어프로그래밍] 230502 3진법 뒤집기 | divmod int (3) | 2023.05.02 |