• 목록
  • 아래로
  • 위로

SIR 디스달나노 님의 질문에 대한 파이썬 스크립트에요 ^-^

 

https://sir.kr/qa/357672

문제1)

$arr = [´A´, ´A´, ´B´, ´B´, ´A´, ´B´, ´A´, ´C´, ´C´, ´C´];

무작위로 배열...

 

 

질문 내용 펌:

                                                                               

문제1)

$arr = ['A', 'A', 'B', 'B', 'A', 'B', 'A', 'C', 'C', 'C'];

무작위로 배열에 알파벳이 저장되어 있다.

 

다음과 같은 알파벳의 위치를 배열에 저장하시오.

단! 함수를 사용하여 배열의 리턴값을 받으시오.

 

$result = 함수($arr)

 

결과값 :

$result[0] = "A, 0, 1, 4, 6";

$result[1] = "B, 2, 3, 5";

$result[2] = "C, 7, 8, 9";

                                                                               

 

 

위 질문에 대해 파이썬으로 A~Z까지 일반적으로 작동하는 함수를 작성해봤네요~!

 

너무 오래 파이썬을 쉬면 감이 떨어져서 말이죠 ㅠㅠ

 

문제에서 아스키 코드를 이용하지 않는 풀이를 요구한다면 한참 길어질 것 같네요 ㄷㄷ

 

그리고 이런 유형의 문제를 풀 때에는 적절한 초기값의 리스트를 생성하는게 편하더군요 :)

 

 

def func(list):
    res = []
    # A~Z까지 리스트 안의 리스트를 생성합니다.
    for i in range(26):
        res.append([chr(65 + i)])
    # 각 문자의 위치를 리스트에 넣습니다.
    for idx1, l in enumerate(list):
        res[ord(l) - 65].append(idx1)
    # 리스트 안의 리스트의 길이가 1인 경우를 제외하여 새 리스트를 생성합니다.
    final = [x for x in res if len(x) != 1]
    return final

data = ['A', 'A', 'B', 'B', 'A', 'B', 'A', 'C', 'C', 'C']
result = func(data)
print(result)

 

결과 :  [['A', 0, 1, 4, 6], ['B', 2, 3, 5], ['C', 7, 8, 9]]

 

 

마지막에 새 리스트를 생성하는 방식이 아니라 del이나 remove를 for문에서 돌리는 방식을 택하면 

 

del이나 remove가 작동할 때마다 리스트의 길이가 짧아지기 때문에 제대로 된 결과를 얻을 수 없어요 ㅠㅠ

 

작성자
이니스프리 119 Lv. (0%) 1930110/115200000EXP

Make StudyForUs Great Again!

 

CSVpuymXAAAVVpd.jpg

댓글 5

title: 황금 서버 (30일)humit
profile image

dictionary 자료형을 사용하는 방법도 있습니다 :)

 

 

arr = ['A', 'A', 'B', 'B', 'A', 'B', 'A', 'C', 'C', 'C']

m = {}
for idx, item in enumerate(arr):
    if item in m:
        m[item].append(idx)
    else:
        m[item] = [idx]

result = [[k, *v] for k,v in sorted(m.items())]
 

comment menu
2020.05.05. 23:29

신고

"humit님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → humit
profile image

오오~ 빈 리스트에서 append를 할 수 없는 문제를 이렇게 if문으로 처리하면 되는군요 ㅎㄷㄷ
별표를 이용한 가변인자는 전혀 생각도 못했네요~!
역시 이런게 파이써닉한 코딩이군요!! ㄷㄷ

humit 님 덕분에 많이 배우고 가네요 ^-^
번번이 정말 감사드립니다~!
코로나 때문에 학사일정이 꼬이셨겠지만 이번 학기도 홧팅하시고 항상 건강하세요 :)

comment menu
2020.05.05. 23:42

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

title: 황금 서버 (30일)humit → 이니스프리
profile image
comment menu
2020.05.05. 23:58

신고

"humit님의 댓글"

이 댓글을 신고 하시겠습니까?

title: 황금 서버 (30일)humit
profile image
python collections 쪽 문서를 보다가 좋은 자료형을 발견했네요.
해당 자료형을 쓰면 따로 if 문으로 분기를 해주지 않아도 됩니다 :)

from collections import defaultdict
arr = ['A', 'A', 'B', 'B', 'A', 'B', 'A', 'C', 'C', 'C']

m = defaultdict(list)
for idx, item in enumerate(arr):
m[item].append(idx)

result = [[k, *v] for k,v in sorted(m.items())]
comment menu
2020.05.09. 13:03

신고

"humit님의 댓글"

이 댓글을 신고 하시겠습니까?

이니스프리 작성자 → humit
profile image
오오~ defaultdict라는 유사 딕셔너리가 있었군요 ㅎㄷㄷ
collections는 무궁무진하네요~!
즐거운 주말 되세요~ 감사합니다 :)
comment menu
2020.05.09. 14:48

신고

"이니스프리님의 댓글"

이 댓글을 신고 하시겠습니까?

권한이 없습니다.
번호 제목 글쓴이 날짜 조회 수
공지 [작업 완료] 설 명절 맞이 서버 업데이트 안내 3 마스터 마스터 24.02.11.17:21 830
공지 [중요] 호스팅 만료와 관련하여 일부 수칙이 변경됩니다. 4 마스터 마스터 23.01.14.02:23 4503
428 [학습정보] 구글 게이밍 아카데미 2/18 9 image 이니스프리 이니스프리 19.02.05.16:38 188
427 [끝말잇기] '슘'으로 시작되는 단어 중 XE타운에서 사용할 수 있는 단어 이니스프리 이니스프리 19.08.25.01:01 190
426 [Telegram] Bot의 inline keyboard 제거 이니스프리 이니스프리 22.07.01.20:35 190
425 Bose Sleepbuds의 사용 환경 등에 관하여 이니스프리 이니스프리 18.12.31.14:01 192
424 엠팍에서 첨부 이미지 크롤링을 할 때 400대 에러가 뜨는 경우 이니스프리 이니스프리 20.01.12.23:38 192
423 [파이썬] 딕셔너리의 키/값으로 정렬하기 이니스프리 이니스프리 20.02.02.23:25 195
422 [할인정보] 바디샵 3+3 $50 이상 브리티쉬로즈 증정 image 이니스프리 이니스프리 17.02.17.22:16 196
421 [생활정보] 기존 영역 벗어나 새로워진  편의점 크로스오버 상품 5 image 이니스프리 이니스프리 17.01.23.16:24 197
420 [Python] Bypassing Cloudflare's anti-bot page with Cloudscraper module 이니스프리 이니스프리 22.06.10.22:11 197
419 [할인정보] DHC - 2/15-2/16 스베스베 데이 전품목 30% SALE! 4 image 이니스프리 이니스프리 17.02.15.21:41 198
418 [Python] 윈도우에서 파이썬이 설치된 경로를 확인하는 방법 이니스프리 이니스프리 20.05.13.22:13 198
417 [Python] dictionary 자료형에서 setdefault와 update의 차이 이니스프리 이니스프리 20.04.05.18:12 199
416 [이벤트] 롯데리아 행쇼팩 9900원과 핫크리스피버거 1+1 image 부루마블 17.01.25.23:05 200
415 파이썬 & 데이터 분석 & 웹 크롤링 오프라인 강의 image 이니스프리 이니스프리 19.11.03.01:41 200
414 [Python] 네이버 블로그 크롤링할 때 PostList.nhn 관련 팁 (문자열에서 첫번째 행을 제거하기) 이니스프리 이니스프리 20.11.08.18:16 202
413 [Python] 확장자를 지정할 수 있는 백업 스크립트 이니스프리 이니스프리 20.05.13.21:58 203
412 [Matplotlib] X축 눈금 레이블 텍스트를 회전시키는 방법 이니스프리 이니스프리 22.07.18.21:05 204
411 이것 7가지 지키면 미세먼지 노출 줄일 수 있다! image 오후두시스토리 오후두시스토.. 17.04.06.11:12 207
410 [할인정보] 콰트로치즈와퍼주니어 44% 할인 + 오리지널 또는 골드 치킨프라이 50% 할인 3 image 이니스프리 이니스프리 17.03.13.12:18 208
409 [Python] How to send BOLD text with Telegram bot 이니스프리 이니스프리 23.08.10.19:51 209