I want to write a function that would return the length of the shortest string in a string of words. Sample: \"I eat apples\" would return 1 since \"I\" is the shorted string. T
You can use min
with a key function:
# split the string by spaces and pick the min based on the lenght of splitted string
# Example:
string = "I eat apples"
final = min(string.split(), key = lambda x: len(x))
print(final)
# >>> I
I would suggest @pramod's answer if you want a quick and easy solution, but I will use your function and show you what happened.
def find_shortest(string):
smallest_length = 99
for word in string.split():
current_length = 0
for letter in word:
current_length += 1
if current_length < smallest_length:
smallest_length = min_length
return smallest_length
min
was renamed. Since min is already defined as a function, this may cause issues.for word in string
to for word in string.split()
. By default split() separates the string into a list based on whitespace. Previously you were simply iterating through every character, which is problematic.Note: smallest_length
being set to 99 assumes that the length of the smallest word is 99 characters or less. Set it higher for larger words.
A function to estabilish the lenght of the smallest word in a text
def lenmin(text):
return len(min(text.split()))
lenmin("I eat apples")
This will return 1
Using lambda
>>> lenmin = lambda t: len(min(t.split()))
>>> lenmin("you eat apples")
2
line = "I eat apples"
mins = min(len(word) for word in line.split())
print(mins)
line.split()
will split line into list of words and then just finding the minimum length