2020. 3. 12. 21:17ㆍPython/CodeSignal Algorithm
31. You have deposited a specific amount of money into your bank account. Each year your balance increases at the same growth rate. With the assumption that you don't make any additional deposits, find out how long it would take for your balance to pass a specific threshold.
[Example]
For deposit = 100, rate = 20, and threshold = 170, the output should be Each year the amount of money in your account increases by 20%. So throughout the years, your balance would be:
Thus, it will take 3 years for your balance to pass the threshold, so the answer is 3. |
[Solution]
#<My Code>
def depositProfit(deposit, rate, threshold):
depo= deposit
cnt = 0
while True:
depo *= (1 + rate / 100)
cnt += 1
if threshold <= depo:
return cnt
#<Best Code>
def depositProfit(deposit, rate, threshold):
return math.ceil(math.log(threshold/deposit, 1+rate/100))
32. You have deposited a specific amount of money into your bank account. Each year your balance increases at the same growth rate. With the assumption that you don't make any additional deposits, find out how long it would take for your balance to pass a specific threshold.
[Example]
For deposit = 100, rate = 20, and threshold = 170, the output should be Each year the amount of money in your account increases by 20%. So throughout the years, your balance would be: |
[Solution]
#<My Code>
def depositProfit(deposit, rate, threshold):
depo= deposit
cnt = 0
while True:
depo *= (1 + rate / 100)
cnt += 1
if threshold <= depo:
return cnt
#<Best Code>
def depositProfit(deposit, rate, threshold):
return math.ceil(math.log(threshold/deposit, 1+rate/100))
32. iven a sorted array of integers a, your task is to determine which element of a is closest to all other values of a. In other words, find the element x in a, which minimizes the following sum:
abs(a[0] - x) + abs(a[1] - x) + ... + abs(a[a.length - 1] - x) |
(where abs denotes the absolute value)
If there are several possible answers, output the smallest one.
[Example]
|
[Solution]
#<My Code>
def absoluteValuesSumMinimization(a):
minAbs, l = 0, 0
for i in range(len(a)):
sumAbs = 0
for j in range(len(a)):
if(i == 0):
sumAbs += abs(a[i] - a[j])
minAbs = sumAbs
l = i
else:
sumAbs += abs(a[i] - a[j])
if minAbs > sumAbs:
minAbs = sumAbs
l = i
return a[l]
#<Best Code>
def absoluteValuesSumMinimization(A):
return A[(len(A)-1)//2]
33. Given an array of equal-length strings, you'd like to know if it's possible to rearrange the order of the elements in such a way that each consecutive pair of strings differ by exactly one character. Return true if it's possible, and false if not.
[Example]
|
[Solution]
def stringsRearrangement(inputArray):
'Python > CodeSignal Algorithm' 카테고리의 다른 글
[Python] CodeSignal 문제 풀이 (34~36) (0) | 2020.03.31 |
---|---|
[Python] CodeSignal 문제 풀이 (33~35) (0) | 2020.03.21 |
[Python] CodeSignal 문제 풀이 (28~30) (0) | 2020.03.12 |
[Python] CodeSignal 문제 풀이 (25~27) (0) | 2020.03.12 |
[Python] CodeSignal 문제 풀이 (22~24) (0) | 2020.03.12 |