📌  相关文章
📜  第12类RD Sharma解决方案–第18章,最大值和最小值–练习18.5 |套装2(1)

📅  最后修改于: 2023-12-03 15:27:24.497000             🧑  作者: Mango

RD Sharma解决方案–第12类,第18章 最大值和最小值,练习18.5 | 套装2

RD Sharma解决方案提供了一个丰富的内容,以帮助学生解决各种数学难题。第12类涵盖了一系列最大值和最小值的概念,其中练习18.5 | 套装2更加深入地探讨了这个话题。

在本练习中,我们将学习如何使用变量和算法来找到一组数据中的最小值和最大值。我们还将深入探讨一些复杂的问题,例如如何找到第二小的元素和第二大的元素。

解决方案

问题:在给定的一组n个整数中找到最小值和最大值。

解决方案:使用变量保存最小值和最大值,然后遍历整个数组以找到这两个值。

def minMax(arr, n):
    max = arr[0]
    min = arr[0]
     
    for i in range(1, n):
        if arr[i] > max:
            max = arr[i]
        elif arr[i] < min:
            min = arr[i]
             
    return (max, min)

在上面的代码中,我们将数组的第一个元素分配给变量max和min。然后,我们开始遍历整个数组。如果我们找到一个比max更大的元素,那么我们将将它分配给max变量。同样,如果我们找到一个比min更小的元素,则它被分配给min变量。一旦我们遍历完整个数组,我们就可以返回max和min。

问题:在给定的一组n个整数中找到第二小的元素。

解决方案:使用两个变量,一个用于存储最小值,另一个用于存储第二小的值。遍历整个数组,比较每个元素的大小,找到最小值和第二小的值。

def secondSmallest(arr, n):
    if n < 2:
        return -1
     
    smallest = arr[0]
    second_smallest = arr[1] if arr[1] < arr[0] else float('inf')
     
    for i in range(2, n):
        if arr[i] < smallest:
            second_smallest = smallest
            smallest = arr[i]
        elif arr[i] < second_smallest and arr[i] != smallest:
            second_smallest = arr[i]
             
    if second_smallest == float('inf'):
        return -1
    else:
        return second_smallest

在上面的代码中,我们先检查数组大小,如果小于2,直接返回-1。然后,我们将数组的前两个元素分配给smallest和second_smallest变量。然后,我们开始遍历整个数组。如果我们找到一个比smallest更小的元素,则我们将smallest分配给second_smallest,并将新的最小元素分配给smallest。如果我们找到的元素比second_smallest小但大于最小元素,则将其分配给second_smallest。一旦我们遍历完整个数组,我们就可以返回second_smallest。

问题:在给定的一组n个整数中找到第二大的元素。

解决方案:可以使用与上一个问题相同的方法来解决。但是我们需要找到最大值和第二大的值。

def secondLargest(arr, n):
    if n < 2:
        return -1
     
    largest = max(arr[0], arr[1])
    second_largest = min(arr[0], arr[1])
     
    for i in range(2, n):
        if arr[i] > largest:
            second_largest = largest
            largest = arr[i]
        elif arr[i] > second_largest and arr[i] != largest:
            second_largest = arr[i]
             
    if second_largest == float('-inf'):
        return -1
    else:
        return second_largest

在上面的代码中,我们遍历整个数组并找到最大元素和第二大元素。一旦我们遍历完整个数组,我们就返回second_largest。

结论

在本文中,我们解决了一组数据中的最大值和最小值的问题。我们还解决了如何找到第二小的元素和第二大的元素的问题。这些解决方案可以通过使用变量和算法来实现。