C++另一个数组中较小值的排列

c++另一个数组中较小值的排列

本教程中提供了两个数组 A 和 B。例如,我们需要输出 A 的任意排列,使得 A[ I ] > B[ I ] 的索引最大化,例如

Input: A = [12, 22, 41, 13],B = [1, 20, 10, 12]Output: 12, 22, 41, 13Input: A = [2, 5, 9, 7],B = [1, 12, 4, 54]Output: 2 7 5 9Multiple answers can be present in that case we are simply going to print any one of the answers.

在这个问题中,我们需要最大化 A[ i ] > B[ i ] 处的索引,因此我们将贪婪地解决这个问题。

寻找解决方案的方法

在这种方法中,我们现在首先对两个数组进行排序;我们贪婪地检查数组 B 的每个索引,使得 A[ i ] 比它更重要,然后将该元素放入向量中。

示例

#include using namespace std;int main(){    int A[] = { 2, 5, 9, 7 };    int B[] = { 1, 12, 4, 54 };    int n = sizeof(A) / sizeof(int); // size of our arrays    vector<pair > A_pair, B_pair;    /***********************We are linking element to its position***********/    for (int i = 0; i < n; i++)        A_pair.push_back({A[i], i});    for (int i = 0; i < n; i++)        B_pair.push_back({B[i], i});    /***********************************************************************/    /*****Sorting our pair vectors********************/    sort(A_pair.begin(), A_pair.end());    sort(B_pair.begin(), B_pair.end());    int i = 0, j = 0, ans[n];    memset(ans, -1, sizeof(ans)); // initializing all the elements with value -1    vector remaining; // this will store our elements which have lesser value than elemnt present in B.    while (i < n && j  B_pair[j].first) {            ans[B_pair[j].second] = A_pair[i].first;            i++;            j++;        }        else {            remaining.push_back(i);            i++;        }    }    j = 0;    for (int i = 0; i < n; ++i){        // now if any index of answer is unchanged so that means        //we need to fill that position with the remaining elements        if (ans[i] == -1){            ans[i] = A_pair[remaining[j]].first;            j++;        }    }    for (int i = 0; i < n; i++) // printing our answer        cout << ans[i] << " ";    return 0;}

输出

2 7 5 9

上述代码的解释

在这种方法中,我们首先将所有元素链接到它们的索引,以便在排序时仍然保留它们的旧索引。我们对两个向量对进行排序,现在我们在遍历两个数组时贪婪地搜索答案,如果我们得到 A_pair 的索引,它比 B_pair 具有更优异的值,因此我们将其存储在我们的数组中(并在B_pair 的位置)否则,因为我们已经对两个向量进行了排序,所以我们知道我们将无法使用 A_pair 的这个值,所以我们将该元素索引推入剩余的向量中,现在我们借助剩余的填充数组向量,然后打印答案。

立即学习“C++免费学习笔记(深入)”;

结论

在本教程中,我们解决了一个问题,从另一个数组中找到具有较小值的数组的排列。我们还学习了这个问题的C++程序以及我们解决的完整方法。我们可以用其他语言比如C、java、python等语言来编写同样的程序。我们希望本教程对您有所帮助。

以上就是C++另一个数组中较小值的排列的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1444250.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 21:15:42
下一篇 2025年12月17日 21:16:08

相关推荐

  • 如何在C语言中将数组中的单个元素作为参数传递给函数?

    如果要将单个元素作为参数传递,则在函数调用中必须给出数组元素及其下标。 为了接收这些元素,在函数定义中使用简单变量。 示例1 #includemain (){ void display (int, int); int a[5], i; clrscr(); printf (“enter 5…

    2025年12月17日
    000
  • C/C++程序中的数组

    数组是一组固定数量的相同数据类型的项目。这些元素存储在内存中的连续内存位置中。 可以使用方括号“[]”和数组名称像a[4]、a[3]等从其索引值访问值的每个单个元素。 声明数组 在c/c++编程语言中,通过定义数组的类型和长度(元素数量)来声明数组。下面的语法显示了在c/c++中声明数组的方法− d…

    2025年12月17日
    000
  • 使用C++编写代码,找到具有K个逆序对的排列数量

    在数组中,如果 a[i] > a[j] 且 i 排列以完美的 K 反转结束。这是例子 – Input: N = 4, K = 1Output: 3Explanation: Permutation of the first N numbers in total : 1234, 124…

    2025年12月17日
    000
  • C++程序以递增顺序重新排列数组中所有x的倍数元素

    我们有一个整数类型的数组 `int arr[]` 和一个整数类型的变量 `x`。任务是重新排列数组的所有元素,使它们能够被给定的整数值 `x` 整除,并且排列顺序应该是递增的。 让我们看看这个问题的各种输入输出情况: 输入 – int arr[] = {4,24, 3, 5, 7, 22…

    2025年12月17日
    000
  • 在C语言中,结构体(Structure)和数组(Array)之间的区别是什么?

    在 C 中,结构体和数组都用作数据类型的容器,即在结构体和数组中我们都可以存储数据,也可以对它们执行不同的操作。 基于内部实现,以下是两者之间存在一些基本差异。 Sr.编号 键 结构 数组 1定义结构体可以定义为一种数据结构,用作容器,可以容纳不同类型的变量。另一方面,数组是一种用作容器的数据结构,…

    2025年12月17日
    000
  • 使用交换最小化两个数组中最大数的乘积

    数据结构操作现在已成为现代编程和计算中成功解决方案开发的一个重要方面。这是由于随着时间的推移,这些结构所呈现的复杂性不断增加。一个例子是执行交换操作以最小化包含在两个数组中的最大数的总和,从而降低它们的整体值。在这篇文章中,我们讨论了两种使用C++完成这些任务的方法,同时根据不同观点承认了这两种方法…

    2025年12月17日
    000
  • 在C程序中,将一个数组中具有最大AND值的一对元素打印出来

    根据问题,我们给定了一个包含n个正整数的数组,我们需要从数组中找到具有最大AND值的一对。 示例 Input: arr[] = { 4, 8, 12, 16 }Output: pair = 8 12The maximum and value= 8Input:arr[] = { 4, 8, 16, 2…

    2025年12月17日
    000
  • 在C++中,查找未排序数组中元素的起始索引和结束索引

    在这个问题中,我们得到一个包含 n 个未排序整数值的数组 aar[] 和一个整数 val。我们的任务是在未排序的数组中查找元素的开始和结束索引。 对于数组中元素的出现,我们将返回, “起始索引和结束索引”(如果在数组中找到两次或多次)。 “单个索引”(如果找到) 立即学习“C++免费学习笔记(深入)…

    2025年12月17日
    000
  • 在C语言中找到导致归并排序最坏情况的排列

    概念 对于给定的元素集合,确定哪种排列方式会导致归并排序的最坏情况? 我们知道,渐进地,归并排序总是需要O(n log n)的时间,但是在实践中,需要更多比较的情况通常需要更多时间。现在我们基本上需要确定一种输入元素的排列方式,使得在实现典型的归并排序算法时,比较次数最多。 示例  考虑下面的元素集…

    2025年12月17日
    000
  • 将数组表示的数字加1(递归方法)

    给定一个数组,该数组是由非负数字表示的数字的集合,将数字加1(增加由数字表示的数字)。数字存储方式是最高位数字是数组的第一个元素。 要将数字加1到由数字表示的数字 从数组末尾开始,加法意味着将最后一个数字4舍入为5。 如果最后一个元素是9,则将其变为0并进位=1。 对于下一次迭代,检查进位,如果加到…

    2025年12月17日
    000
  • 使用C语言在数组中插入元素

    我们可以在任意位置插入元素,这意味着我们可以在数组的起始位置、中间、最后或任意位置插入。 在数组中插入元素后,位置或索引位置增加,但并不意味着数组的大小增加。 插入元素的逻辑是− 输入数组的大小 立即学习“C语言免费学习笔记(深入)”; 输入要插入元素的位置 接下来输入您要在该位置插入的数字 for…

    2025年12月17日
    000
  • 在C语言中,什么是数组的越界索引?

    假设您有一个包含四个元素的数组。那么,数组索引将从0到3,即我们可以访问索引0到3的元素。 但是,如果我们使用大于3的索引,它将被称为索引越界。 如果我们使用越界的数组索引,那么编译器将编译甚至运行。但是,不能保证结果正确。 结果可能不确定,并且会导致许多问题。因此,建议在使用数组索引时要小心。 立…

    2025年12月17日
    000
  • 数组元素的频率是否为质数?

    Suppose we have one array. we have to count how many of the elements present in the array prime number of times. So if the array is {1, 2, 2, 0, 1, 5,…

    2025年12月17日
    000
  • C语言中的数组

    数组是连续内存位置上相同类型元素的集合。最低地址对应于第一个元素,最高地址对应于最后一个元素。 数组索引以零 (0) 开始,以数组大小减一(数组大小 – 1)结束。数组大小必须是大于零的整数。 让我们看一个例子, If array size = 10First index of arra…

    2025年12月17日
    000
  • 如何在C语言中将数组的元素以相反的顺序打印出来?

    尝试按照下面给出的算法以相反的顺序打印元素: 步骤1 – 声明一个大小为5的数组 步骤2 – 使用for循环将5个元素输入到内存中 步骤3 – 以相反的顺序显示元素 立即学习“C语言免费学习笔记(深入)”; 通过递减for循环 唯一的逻辑是通过for循环反转元素:…

    2025年12月17日
    000
  • 找到给定大小的二进制字符串数组中不存在的任意排列

    在这个问题中,我们需要从数组中找到长度为N的所有缺失的二进制字符串。我们可以通过找到长度为N的二进制字符串的所有排列,并检查哪些排列在数组中不存在来解决这个问题。在这里,我们将看到迭代和递归的方法来解决这个问题。 问题陈述 – 我们已经给出了一个包含不同长度的二进制字符串的数组arr[]…

    2025年12月17日
    000
  • Avalonia StackPanel和DockPanel有什么区别 Avalonia布局控件使用方法

    StackPanel 顺序堆叠、方向固定,适合线性结构;DockPanel 边缘停靠、顺序敏感,适合区域划分。选错易致错位或响应异常,应据结构意图选择:线性用 StackPanel,分区用 DockPanel。 StackPanel 和 DockPanel 是 Avalonia 中最常用的两种布局控…

    2025年12月17日
    000
  • C#怎么处理异常 C# try-catch-finally异常捕获方法

    C#异常处理核心是try-catch-finally结构:try执行可能出错代码,catch按从具体到一般顺序捕获异常,finally确保资源清理;推荐用throw;保留堆栈、using替代手动finally。 在C#中处理异常,核心是用 try-catch-finally 结构捕获并响应运行时错误…

    2025年12月17日
    000
  • MAUI中的FlexLayout怎么用 MAUI弹性布局教程

    FlexLayout是.NET MAUI中对标CSS Flexbox的弹性布局容器,适用于内容数量不确定、屏幕尺寸多变的场景,如标签云、自适应卡片列表、折叠屏分栏等。 FlexLayout是什么,适合什么场景 FlexLayout是.NET MAUI中对标CSS Flexbox的弹性布局容器,专为动…

    2025年12月17日
    000
  • Blazor Toast 通知组件的实现方法

    Blazor中实现Toast通知需创建状态模型、ToastService和Toast组件。1. 状态模型含Id、Message、Type等字段;2. ToastService注册为Scoped服务,管理增删通知及定时关闭;3. Toast组件用@foreach渲染并绑定CSS动画;4. 在Progr…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信