📌  相关文章
📜  给定数字N的最小奇数和偶数和

📅  最后修改于: 2021-05-07 09:21:10             🧑  作者: Mango

以字符串str的形式给出大量数字。任务是通过从给定的字符串str中删除零个或多个字符来找到数字之和为偶数的最小奇数,在该字符串中可以重新排列数字。
例子

方法:
通过直觉仔细观察,可以理解,最小的奇数中的位数为2。由于两个奇数之和始终为偶数,因此该位数中的每个数字都是奇数。因此,解决此问题的想法是遍历给定的字符串并将每个奇数存储在数组中。可以对这个数组进行排序,并且前两位数字共同构成最小的奇数,其数字之和为偶数。

下面是上述方法的实现。

C++
// C++ program to find the smallest odd number
// with even sum of digits from the given number N
#include
using namespace std;
 
// Function to find the smallest odd number
// whose sum of digits is even from the given string
int smallest(string s)
{
    // Converting the given string
    // to a list of digits
    vector a(s.length());
    for(int i = 0; i < s.length(); i++)
        a[i] = s[i]-'0';
     
    // An empty array to store the digits
    vector b;
     
    // For loop to iterate through each digit
    for(int i = 0; i < a.size(); i++)
    {
         
        // If the given digit is odd then
        // the digit is appended to the array b
        if((a[i]) % 2 != 0)
            b.push_back(a[i]);
    }
             
    // Sorting the list of digits
    sort(b.begin(),b.end());
     
    // If the size of the list is greater than 1
    // then a 2 digit smallest odd number is returned
    // Since the sum of two odd digits is always even
    if(b.size() > 1)
        return (b[0])*10 + (b[1]);
     
    // Else, -1 is returned
    return -1;
}
     
// Driver code
int main()
{
    cout << (smallest("15470"));
}
 
// This code is contributed by Surendra_Gangwar


Java
// Java program to find the smallest
// odd number with even sum of digits
// from the given number N
import java.util.*;
class GFG{
     
// Function to find the smallest
// odd number whose sum of digits
// is even from the given string
public static int smallest(String s)
{
     
    // Converting the given string
    // to a list of digits
    int[] a = new int[s.length()];
    for(int i = 0; i < s.length(); i++)
        a[i] = s.charAt(i) - '0';
     
    // An empty array to store the digits
    Vector b = new Vector();
     
    // For loop to iterate through each digit
    for(int i = 0; i < a.length; i++)
    {
         
        // If the given digit is odd
        // then the digit is appended
        // to the array b
        if(a[i] % 2 != 0)
            b.add(a[i]);
    }
             
    // Sorting the list of digits
    Collections.sort(b);
     
    // If the size of the list is greater
    // than 1 then a 2 digit smallest odd
    // number is returned. Since the sum
    // of two odd digits is always even
    if(b.size() > 1)
        return (b.get(0)) * 10 + (b.get(1));
     
    // Else, -1 is returned
    return -1;
}
 
// Driver code
public static void main(String[] args)
{
    System.out.print(smallest("15470"));
}
}
 
// This code is contributed by divyeshrabadiya07


Python
# Python program to find the smallest odd number
# with even sum of digits from the given number N
 
# Function to find the smallest odd number
# whose sum of digits is even from the given string
def smallest(s):
     
    # Converting the given string
    # to a list of digits
    a = list(s)
     
    # An empty array to store the digits
    b = []
     
    # For loop to iterate through each digit
    for i in range(len(a)):
         
        # If the given digit is odd then
        # the digit is appended to the array b
        if(int(a[i])%2 != 0):
            b.append(a[i])
             
    # Sorting the list of digits
    b = sorted(b)
     
    # If the size of the list is greater than 1
    # then a 2 digit smallest odd number is returned
    # Since the sum of two odd digits is always even
    if(len(b)>1):
        return int(b[0])*10 + int(b[1])
     
    # Else, -1 is returned   
    return -1
 
 
# Driver code
if __name__ == "__main__":
    print(smallest("15470"))


C#
// C# program to find the smallest
// odd number with even sum of digits
// from the given number N
using System;
using System.Collections;
 
class GFG{
      
// Function to find the smallest
// odd number whose sum of digits
// is even from the given string
public static int smallest(string s)
{
     
    // Converting the given string
    // to a list of digits
    int[] a = new int[s.Length];
     
    for(int i = 0; i < s.Length; i++)
        a[i] = (int)(s[i] - '0');
      
    // An empty array to store the digits
    ArrayList b = new ArrayList();
      
    // For loop to iterate through each digit
    for(int i = 0; i < a.Length; i++)
    {
          
        // If the given digit is odd
        // then the digit is appended
        // to the array b
        if (a[i] % 2 != 0)
            b.Add(a[i]);
    }
              
    // Sorting the list of digits
    b.Sort();
      
    // If the size of the list is greater
    // than 1 then a 2 digit smallest odd
    // number is returned. Since the sum
    // of two odd digits is always even
    if (b.Count > 1)
        return ((int)b[0] * 10 + (int)b[1]);
      
    // Else, -1 is returned
    return -1;
}
  
// Driver code
public static void Main(string[] args)
{
    Console.Write(smallest("15470"));
}
}
 
// This code is contributed by rutvik_56


输出:
15

时间复杂度: O(N),其中N =字符串的长度。