Python: Find the second largest number in a list
Find Second Largest Number in List
Write a Python program to find the second largest number in a list.
Example - 1 :
data:image/s3,"s3://crabby-images/fbecc/fbecc6cd4fec2eb824c0da2dd94e919ef62f95a5" alt="Python: Find the second largest number in a list"
Example - 2 :
data:image/s3,"s3://crabby-images/7502f/7502ffd3290a58d1977ce4f050fd0a45b20eb8b2" alt="Python: Find the second largest number in a list"
Example - 3 :
data:image/s3,"s3://crabby-images/7751d/7751d32836a2a79a91f8590ff4cd7c005f01ef04" alt="Python: Find the second largest number in a list"
Example - 4 :
data:image/s3,"s3://crabby-images/190d9/190d9a8e890f8120c009bd8d38d57140848e3246" alt="Python: Find the second largest number in a list"
Sample Solution:
Python Code:
# Define a function named 'second_largest' that takes a list of numbers 'numbers' as a parameter
def second_largest(numbers):
# Check if the length of the 'numbers' list is less than 2; return None in this case
if len(numbers) < 2:
return
# Check if there are only two elements in the 'numbers' list, and they are the same; return None in this case
if len(numbers) == 2 and numbers[0] == numbers[1]:
return
# Create an empty set 'dup_items' to store duplicate items and an empty list 'uniq_items' to store unique items
dup_items = set()
uniq_items = []
# Iterate through the elements in the 'numbers' list
for x in numbers:
# Check if 'x' is not in 'dup_items'; if not, add it to 'uniq_items' and 'dup_items'
if x not in dup_items:
uniq_items.append(x)
dup_items.add(x)
# Sort the 'uniq_items' list in ascending order
uniq_items.sort()
# Return the second largest item from the sorted 'uniq_items' list, which is at index -2 (second from the end)
return uniq_items[-2]
# Call the 'second_largest' function with different lists and print the results
print(second_largest([1, 2, 3, 4, 4]))
print(second_largest([1, 1, 1, 0, 0, 0, 2, -2, -2]))
print(second_largest([2, 2])) # Edge case with two identical elements, returns None
print(second_largest([1])) # Edge case with a single element, returns None
Sample Output:
3 1 None None
Flowchart:
data:image/s3,"s3://crabby-images/90b4c/90b4c15d4d791643512ef81727cb82b2225f1c65" alt="Flowchart: Find the second largest number in a list"
For more Practice: Solve these Related Problems:
- Write a Python program to find the third largest number in a list.
- Write a Python program to find the second largest number in a list without sorting.
- Write a Python program to find the second largest unique number in a list.
- Write a Python program to find the second largest number in a list using a single pass.
Python Code Editor:
Previous: Write a Python program to find the second smallest number in a list.
Next: Write a Python program to get unique values from a list.
What is the difficulty level of this exercise?
Test your Programming skills with w3resource's quiz.
- Weekly Trends and Language Statistics
- Weekly Trends and Language Statistics