热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

删除给定元素后查找最大元素

删除给定元素后查找最大元素原文:https://www.geek

删除给定元素后查找最大元素

原文:https://www.geeksforgeeks.org/find-the-largest-after-deleting-the-given-elements/

给定一个整数数组,请在删除给定元素后找到最大的数字。 如果重复元素,请为包含要删除元素的数组中存在的元素的每个实例删除一个实例。

示例

输入:array[] = {5, 12, 33, 4, 56, 12, 20}, del[] = {12, 33, 56, 5}

输出:20

说明:我们在删除给定元素后得到{12, 20}。 其余元素中最大的是 20

方法


  • 将所有要从数组中删除的数字插入到哈希映射中,以便我们可以检查数组元素是否在O(1)时也出现在删除数组中。


  • 初始化最大值maxINT_MIN


  • 遍历数组。 检查元素是否存在于哈希映射中。


  • 如果存在,则将其从哈希映射中删除;否则,将其与max变量进行比较,如果元素的值大于最大值,则将其值更改。



C++

// C++ program to find the largest number
// from the array after  n deletions
#include "climits"
#include "iostream"
#include "unordered_map"
using namespace std;
// Returns maximum element from arr[0..m-1] after deleting
// elements from del[0..n-1]
int findlargestAfterDel(int arr[], int m, int del[], int n)
{
    // Hash Map of the numbers to be deleted
    unordered_map mp;
    for (int i = 0; i         // Increment the count of del[i]
        mp[del[i]]++;
    }
    // Initializing the largestElement
    int largestElement = INT_MIN;
    for (int i = 0; i         // Search if the element is present
        if (mp.find(arr[i]) != mp.end()) {
            // Decrement its frequency
            mp[arr[i]]--;
            // If the frequency becomes 0,
            // erase it from the map
            if (mp[arr[i]] == 0)
                mp.erase(arr[i]);
        }
        // Else compare it largestElement
        else
            largestElement = max(largestElement, arr[i]);
    }
    return largestElement;
}
int main()
{
    int array[] = { 5, 12, 33, 4, 56, 12, 20 };
    int m = sizeof(array) / sizeof(array[0]);
    int del[] = { 12, 33, 56, 5 };
    int n = sizeof(del) / sizeof(del[0]);
    cout <    return 0;
}

Java

// Java program to find the largest number
// from the array after n deletions
import java.util.*;
class GFG 
{
// Returns maximum element from arr[0..m-1] after deleting
// elements from del[0..n-1]
static int findlargestAfterDel(int arr[], int m,
                               int del[], int n)
{
    // Hash Map of the numbers to be deleted
    HashMap            Integer> mp = new HashMap                                      Integer>();
    for (int i = 0; i     {
        // Increment the count of del[i]
        if(mp.containsKey(del[i]))
        {
            mp.put(del[i], mp.get(del[i]) + 1);
        }
        else
        {
            mp.put(del[i], 1);
        }
    }
    // Initializing the largestElement
    int largestElement = Integer.MIN_VALUE;
    for (int i = 0; i     {
        // Search if the element is present
        if (mp.containsKey(arr[i])) 
        {
            // Decrement its frequency
            mp.put(arr[i], mp.get(arr[i]) - 1);
            // If the frequency becomes 0,
            // erase it from the map
            if (mp.get(arr[i]) == 0)
                mp.remove(arr[i]);
        }
        // Else compare it largestElement
        else
            largestElement = Math.max(largestElement, arr[i]);
    }
    return largestElement;
}
// Driver Code
public static void main(String[] args) 
{
    int array[] = { 5, 12, 33, 4, 56, 12, 20 };
    int m = array.length;
    int del[] = { 12, 33, 56, 5 };
    int n = del.length;
    System.out.println(findlargestAfterDel(array, m, del, n));    
}
}
// This code is contributed by Rajput-Ji

Python3

# Python3 program to find the largest 
# number from the array after n deletions
import math as mt
# Returns maximum element from arr[0..m-1] 
# after deleting elements from del[0..n-1]
def findlargestAfterDel(arr, m, dell, n):
    # Hash Map of the numbers
    # to be deleted
    mp = dict()
    for i in range(n):
        # Increment the count of del[i]
        if dell[i] in mp.keys():
            mp[dell[i]] += 1
        else:
            mp[dell[i]] = 1
    # Initializing the largestElement
    largestElement = -10**9
    for i in range(m):
        # Search if the element is present
        if (arr[i] in mp.keys()):
            # Decrement its frequency
            mp[arr[i]] -= 1
            # If the frequency becomes 0,
            # erase it from the map
            if (mp[arr[i]] == 0):
                mp.pop(arr[i])
        # Else compare it largestElement
        else:
            largestElement = max(largestElement, 
                                         arr[i])
    return largestElement
# Driver code
array = [5, 12, 33, 4, 56, 12, 20]
m = len(array)
dell = [12, 33, 56, 5]
n = len(dell)
print(findlargestAfterDel(array, m, dell, n))
# This code is contributed 
# by mohit kumar 29

C

// C# program to find the largest number
// from the array after n deletions
using System;
using System.Collections.Generic;
class GFG 
{
// Returns maximum element from arr[0..m-1] 
// after deleting elements from del[0..n-1]
static int findlargestAfterDel(int []arr, int m,
                               int []del, int n)
{
    // Hash Map of the numbers to be deleted
    Dictionary               int> mp = new Dictionary                                        int>();
    for (int i = 0; i     {
        // Increment the count of del[i]
        if(mp.ContainsKey(del[i]))
        {
            mp[arr[i]] = mp[arr[i]] + 1;
        }
        else
        {
            mp.Add(del[i], 1);
        }
    }
    // Initializing the largestElement
    int largestElement = int.MinValue;
    for (int i = 0; i     {
        // Search if the element is present
        if (mp.ContainsKey(arr[i])) 
        {
            // Decrement its frequency
            mp[arr[i]] = mp[arr[i]] - 1;
            // If the frequency becomes 0,
            // erase it from the map
            if (mp[arr[i]] == 0)
                mp.Remove(arr[i]);
        }
        // Else compare it largestElement
        else
            largestElement = Math.Max(largestElement, 
                                             arr[i]);
    }
    return largestElement;
}
// Driver Code
public static void Main(String[] args) 
{
    int []array = { 5, 12, 33, 4, 56, 12, 20 };
    int m = array.Length;
    int []del = { 12, 33, 56, 5 };
    int n = del.Length;
    Console.WriteLine(findlargestAfterDel(array, m, del, n)); 
}
}
// This code is contributed by Princi Singh

输出

20

时间复杂度O(n)





推荐阅读
  • 本文详细介绍如何使用Python进行配置文件的读写操作,涵盖常见的配置文件格式(如INI、JSON、TOML和YAML),并提供具体的代码示例。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 从 .NET 转 Java 的自学之路:IO 流基础篇
    本文详细介绍了 Java 中的 IO 流,包括字节流和字符流的基本概念及其操作方式。探讨了如何处理不同类型的文件数据,并结合编码机制确保字符数据的正确读写。同时,文中还涵盖了装饰设计模式的应用,以及多种常见的 IO 操作实例。 ... [详细]
  • Python 异步编程:深入理解 asyncio 库(上)
    本文介绍了 Python 3.4 版本引入的标准库 asyncio,该库为异步 IO 提供了强大的支持。我们将探讨为什么需要 asyncio,以及它如何简化并发编程的复杂性,并详细介绍其核心概念和使用方法。 ... [详细]
  • 本文详细介绍了Java中org.neo4j.helpers.collection.Iterators.single()方法的功能、使用场景及代码示例,帮助开发者更好地理解和应用该方法。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • Java 类成员初始化顺序与数组创建
    本文探讨了Java中类成员的初始化顺序、静态引入、可变参数以及finalize方法的应用。通过具体的代码示例,详细解释了这些概念及其在实际编程中的使用。 ... [详细]
  • 本文详细介绍了Java编程语言中的核心概念和常见面试问题,包括集合类、数据结构、线程处理、Java虚拟机(JVM)、HTTP协议以及Git操作等方面的内容。通过深入分析每个主题,帮助读者更好地理解Java的关键特性和最佳实践。 ... [详细]
  • 本文详细探讨了KMP算法中next数组的构建及其应用,重点分析了未改良和改良后的next数组在字符串匹配中的作用。通过具体实例和代码实现,帮助读者更好地理解KMP算法的核心原理。 ... [详细]
  • 优化ListView性能
    本文深入探讨了如何通过多种技术手段优化ListView的性能,包括视图复用、ViewHolder模式、分批加载数据、图片优化及内存管理等。这些方法能够显著提升应用的响应速度和用户体验。 ... [详细]
  • 本文详细介绍了 GWT 中 PopupPanel 类的 onKeyDownPreview 方法,提供了多个代码示例及应用场景,帮助开发者更好地理解和使用该方法。 ... [详细]
  • PyCharm下载与安装指南
    本文详细介绍如何从官方渠道下载并安装PyCharm集成开发环境(IDE),涵盖Windows、macOS和Linux系统,同时提供详细的安装步骤及配置建议。 ... [详细]
  • Explore a common issue encountered when implementing an OAuth 1.0a API, specifically the inability to encode null objects and how to resolve it. ... [详细]
  • 本文介绍如何使用Objective-C结合dispatch库进行并发编程,以提高素数计数任务的效率。通过对比纯C代码与引入并发机制后的代码,展示dispatch库的强大功能。 ... [详细]
  • 在维护公司项目时,发现按下手机的某个物理按键后会激活相应的服务,并在屏幕上模拟点击特定坐标点。本文详细介绍了如何使用ADB Shell Input命令来模拟各种输入事件,包括滑动、按键和点击等。 ... [详细]
author-avatar
老男孩标兄_164
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有