ursobad
ursobad
ursobad
전체 방문자
오늘
어제
  • 분류 전체보기 (116)
    • Emotion (35)
      • 파이썬 (10)
      • 문제 (10)
      • 인공지능 기초 (15)
    • Best of the Best (3)
    • Hacking (58)
      • HackCTF (12)
      • DreamHACK (7)
      • Webhacking.kr (19)
      • Root Me (6)
      • HTB (5)
      • 기타 (7)
      • 리버싱 소수전공 (2)
    • 기능반 (16)
      • 2과제 (14)
      • 3과제 (2)
    • 기록 (3)
    • 짧은 글들 (0)
    • 기타 (1)
    • Zombie (0)

블로그 메뉴

  • 홈
  • 태그
  • 방명록

공지사항

인기 글

태그

  • 얼굴검출
  • BoB 자소서
  • Python
  • 의사결정트리
  • BoB 질문
  • BoB 자기소개
  • 앙상블
  • 백준
  • KNN
  • Bob
  • 함수
  • 123
  • 머신러닝
  • 구독자 전용 다시보기
  • 파이썬
  • BoB 필기
  • BoB 자기소개서
  • OpenCV
  • BoB 11기
  • BoB 면접

최근 댓글

최근 글

티스토리

hELLO · Designed By 정상우.
ursobad
Emotion/문제

백준 달팽이는 올라가고싶다, 별찍기_21

Emotion/문제

백준 달팽이는 올라가고싶다, 별찍기_21

2020. 8. 26. 16:02

달팽이는 올라가고싶다

문제

땅 위에 달팽이가 있다. 이 달팽이는 높이가 V미터인 나무 막대를 올라갈 것이다.

달팽이는 낮에 A미터 올라갈 수 있다. 하지만, 밤에 잠을 자는 동안 B미터 미끄러진다. 또, 정상에 올라간 후에는 미끄러지지 않는다.

달팽이가 나무 막대를 모두 올라가려면, 며칠이 걸리는지 구하는 프로그램을 작성하시오.

입력

첫째 줄에 세 정수 A, B, V가 공백으로 구분되어서 주어진다. (1 ≤ B < A ≤ V ≤ 1,000,000,000)

출력

첫째 줄에 달팽이가 나무 막대를 모두 올라가는데 며칠이 걸리는지 출력한다.

 

Python 풀이

처음엔 while문으로 풀었다.

a,b,v = map(int,input().split())
cnt = 0
while 1:
    v-=a
    cnt+=1
    if v<=0:
        break
    v+=b
print(cnt)

이렇게 푸니까 시간초과가 떳다.

아마 반복문을 사용하지 않아야될 것 같았다

 

어짜피 마지막날에는 a만큼 올라가야 하기때문에 (v-a)/(a-b)+1이런 공식이 나온다.

하지만 마지막날 a만큼 올라가도 v에 조금남아서 도착하지 못한다면 (v-a)/(a-b)+2를 해줘야 할것이다.

이것을 if else문으로 작성한다.

 

a,b,v = map(int,input().split())
#마지막날에는 어짜피 a만큼 올라가기때문에 v-a
aw = (v-a)//(a-b)

if (v-a)%(a-b) == 0: #마지막날 a만큼 올라가면 v에 도착
    print(aw+1)

else: #마지막날 a만큼 올라가도 v에 도착하지 못한다.
    print(aw+2)

 

별찍기 - 21

문제

예제를 보고 규칙을 유추한 뒤에 별을 찍어 보세요.

입력

첫째 줄에 N(1 ≤ N ≤ 100)이 주어진다.

출력

첫째 줄부터 차례대로 별을 출력한다.

 

입력 : 1

*

 

입력 : 2

*
 *
*
 *

 

입력 : 3

* *
 *
* *
 *
* *
 *

 

입력 : 4

* *
 * *
* *
 * *
* *
 * *
* *
 * *

 

Python 풀이

규칙을 유추하기만 하면된다

일단 줄수는 입력값 * 2이다

짝수줄에는 입력값을 2로 나눈값의 개수만큼 별이 찍힌다

홀수줄에는 입력값의 별개수에서 짝수줄의 별 개수를 뺀만큼 별이 찍힌다

이를 코드로 작성한다.

 

num = int(input())
a = num - num//2 #입력한 값의 별 개수에서 아래 별의 개수를 뺀만큼 별이 찍힌다
b = num//2 #입력한 값을 2로 나눈값의 개수만큼 별이 찍힌다

for i in range(num):
    print("* "*a)
    print(" *"*b)

 

'Emotion > 문제' 카테고리의 다른 글

백준 팩토리얼  (0) 2020.09.02
백준 숫자의 합  (0) 2020.09.02
코드업 1526~1536  (0) 2020.07.08
백준 for문, while문  (0) 2020.07.07
백준 if문  (0) 2020.07.01
  • 달팽이는 올라가고싶다
  • 문제
  • 입력
  • 출력
  • Python 풀이
  • 별찍기 - 21
  • 문제
  • 입력
  • 출력
  • Python 풀이
'Emotion/문제' 카테고리의 다른 글
  • 백준 팩토리얼
  • 백준 숫자의 합
  • 코드업 1526~1536
  • 백준 for문, while문
ursobad
ursobad

티스토리툴바

단축키

내 블로그

내 블로그 - 관리자 홈 전환
Q
Q
새 글 쓰기
W
W

블로그 게시글

글 수정 (권한 있는 경우)
E
E
댓글 영역으로 이동
C
C

모든 영역

이 페이지의 URL 복사
S
S
맨 위로 이동
T
T
티스토리 홈 이동
H
H
단축키 안내
Shift + /
⇧ + /

* 단축키는 한글/영문 대소문자로 이용 가능하며, 티스토리 기본 도메인에서만 동작합니다.