본문 바로가기

알고리즘/백준

0812 백준 알고리즘 11720, 10809, 2675, 1157 풀이

0812 백준 알고리즘 풀이

전체적인 느낌은 오랜만에 푸니까 기본적인것도 잘 생각이 안나더라......

그리고 알고리즘보단 문법위주고, 기본적인 것들이라 오히려 생소하고 낯설다.

11720 숫자의 합

문제
N개의 숫자가 공백 없이 쓰여있다. 이 숫자를 모두 합해서 출력하는 프로그램을 작성하시오.

입력
첫째 줄에 숫자의 개수 N (1 ≤ N ≤ 100)이 주어진다. 둘째 줄에 숫자 N개가 공백없이 주어진다.

출력
입력으로 주어진 숫자 N개의 합을 출력한다.

 

t = int(input())
a = input()
sum = 0
for i in range(t):
    sum += int(a[i])

print(sum)

11809 알파벳 찾기

 

문제

알파벳 소문자로만 이루어진 단어 S가 주어진다. 각각의 알파벳에 대해서, 단어에 포함되어 있는 경우에는 처음 등장하는 위치를, 포함되어 있지 않은 경우에는 -1을 출력하는 프로그램을 작성하시오.

입력

첫째 줄에 단어 S가 주어진다. 단어의 길이는 100을 넘지 않으며, 알파벳 소문자로만 이루어져 있다.

출력

각각의 알파벳에 대해서, a가 처음 등장하는 위치, b가 처음 등장하는 위치, ... z가 처음 등장하는 위치를 공백으로 구분해서 출력한다.

만약, 어떤 알파벳이 단어에 포함되어 있지 않다면 -1을 출력한다. 단어의 첫 번째 글자는 0번째 위치이고, 두 번째 글자는 1번째 위치이다.

 

alpa = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
# 이걸 노가다로 했는데, 아스키코드를 활용하거나 for문 돌려서도 가능하더라....
a = list(input())
la = []

for i in range(len(alpa)):
    if alpa[i] in a:
        for j in range(len(a)):
            if alpa[i] == a[j]:
                la.append(j)
                alpa[i] = 0
    elif alpa[i] not in a:
        la.append(-1)

print(*la)

 

2675 문자열 반복

 

문제

문자열 S를 입력받은 후에, 각 문자를 R번 반복해 새 문자열 P를 만든 후 출력하는 프로그램을 작성하시오. 즉, 첫 번째 문자를 R번 반복하고, 두 번째 문자를 R번 반복하는 식으로 P를 만들면 된다. S에는 QR Code "alphanumeric" 문자만 들어있다.

QR Code "alphanumeric" 문자는 0123456789ABCDEFGHIJKLMNOPQRSTUVWXYZ\$%*+-./: 이다.

입력

첫째 줄에 테스트 케이스의 개수 T(1 ≤ T ≤ 1,000)가 주어진다. 각 테스트 케이스는 반복 횟수 R(1 ≤ R ≤ 8), 문자열 S가 공백으로 구분되어 주어진다. S의 길이는 적어도 1이며, 20글자를 넘지 않는다. 

출력

각 테스트 케이스에 대해 P를 출력한다.

 

t = int(input())

for i in range(t):
    sa = []
    a, b = input().split()
    for j in range(len(b)):
        for k in range(int(a)):
            sa.append(b[j])

    print(''.join(sa))
    
    ## join 사용법 다시 한번 복습!!!

 

1157 단어 공부

 

문제

알파벳 대소문자로 된 단어가 주어지면, 이 단어에서 가장 많이 사용된 알파벳이 무엇인지 알아내는 프로그램을 작성하시오. 단, 대문자와 소문자를 구분하지 않는다.

입력

첫째 줄에 알파벳 대소문자로 이루어진 단어가 주어진다. 주어지는 단어의 길이는 1,000,000을 넘지 않는다.

출력

첫째 줄에 이 단어에서 가장 많이 사용된 알파벳을 대문자로 출력한다. 단, 가장 많이 사용된 알파벳이 여러 개 존재하는 경우에는 ?를 출력한다.

 

large = ['A', 'B', 'C', 'D', 'E', 'F', 'G', 'H', 'I', 'J', 'K', 'L', 'M', 'N', 'O', 'P', 'Q', 'R', 'S', 'T', 'U', 'V', 'W', 'X', 'Y', 'Z']
small = ['a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z']
la = [0]*26

a = input()

for i in range(len(a)):
    for j in range(26):
        if a[i] == large[j] or a[i] == small[j]:
            la[j] +=1
sa = []
for i in range(26):
    if la[i] == max(la):
        sa.append(i)

if len(sa) != 1:
    print('?')

else:
    print(large[sa[0]])
    
    
    ### 좀더 깔끔하게 하자면 대문자는 upper.small 이렇게 하면 된다.....
    ###
    
    n = input()
n = n.upper()
alpa='ABCDEFGHIJKLMNOPQRSTUVWXYZ'
result = []
for i in alpa:
  result.append(n.count(i))
if result.count(max(result)) > 1:
  print("?")
else:
  print(alpa[result.index(max(result))])

'알고리즘 > 백준' 카테고리의 다른 글

[백준]greedy_11399 ATM  (0) 2020.08.19
[백준]greedy_11047 동전0  (0) 2020.08.18
백준 8958, 4344, 1546  (0) 2020.08.16
0814 백준 1712, 2839  (0) 2020.08.14
0813 백준 알고리즘 1152, 2908, 5622, 2941 풀이  (0) 2020.08.14