使用C++找到数组中的正负值对

使用c++找到数组中的正负值对

在本文中,我们有一个包含不同元素的数组。我们需要打印数组中具有相同绝对值的正负值对,并按排序顺序打印它们,例如 –

Input : arr[] = { 1, -1, 11, 12, 56, 77, -56, -12, -88}Output : -1 1 -12 12 -56 56Input : arr[] = {30, 40, 50, 77, -51, -50, -40}Output : -40 40 -50 50

寻找解决方案的方法

我们首先想到的方法是蛮力法,然后我们还想出了一种称为高效法的方法。我们将讨论这两种方法。

蛮力法

在这种方法中,我们将用一个索引遍历数组,并找到相同的绝对值但不同的索引。

示例

#includeusing namespace std;int main() {   int arr[] = { 1, -1, 11, 12, 56, 77, -56, -12, -88 };   int n = sizeof(arr)/sizeof(int); // size of our array.   vector nums; // the present pairs.   for(int i = 0; i < n; i++) {      for(int j = i+1; j < n; j++) {         if(abs(arr[j]) == abs(arr[i])) { // finding the pairs.            nums.push_back(abs(arr[i]));            break;            // if we found the pair then we can just break as there are distinct elements in the array.         }      }   }   sort(nums.begin(), nums.end());   for(auto x : nums) // printing the pairs.      cout << -x << " " << x << " ";}

输出

-1 1 -12 12 -56 56

在这种方法中,我们使用两个循环来遍历数组并找到另一个元素;如果我们找到另一个元素,我们会从内循环中跳出以加快代码运行速度。现在我们使用了两个for循环,整体的时间复杂度为O(N*N)。N是给定数组的大小,适用于较低的约束条件,但对于较高的约束条件来说并不好,所以现在我们将讨论另一种方法。

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

高效方法

在这种方法中,我们将使用一个哈希映射,这将大大降低我们的时间复杂度。

示例

#includeusing namespace std;int main() {   int arr[] = { 4, 8, 9, -4, 1, -1, -8, -9 };   int n = sizeof(arr)/sizeof(int); // size of our array.   map found; // going to store the count of numbers found.   vector nums; // the present pairs.   for(int i = 0; i < n; i++)      found[abs(arr[i])]++; // increasing the frequency of abs(arr[i]).   for(auto x : found) { // traversing the map.      if(x.second == 2) // if any numbers frequency is two then push it to nums.         nums.push_back(x.first);   }   for(auto x : nums) // printing the pairs.      cout << -x << " " << x << " ";}

输出

-1 1 -4 4 -8 8 -9 9

上述代码的解释

在这种方法中,我们使用哈希图来存储数字的频率;当我们遍历数组时,我们现在正在更新当前元素绝对值的频率,因为您知道所有对的值都为 2,因此我们正在遍历地图。

如果任何数字的频率为 2,然后我们将其存储在 nums 中,最后,我们按排序顺序打印值。 (由于地图包含按排序顺序排列的数字,因此我们不需要对数字向量进行排序)。

结论

在本文中,我们解决了查找对的问题使用散列技术计算数组中的正负值。我们还学习了解决这个问题的C++程序以及解决这个问题的完整方法(正常且高效)。我们可以用其他语言比如C、java、python等语言来编写同样的程序。我们希望这篇文章对您有所帮助。

以上就是使用C++找到数组中的正负值对的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:36:33
下一篇 2025年12月11日 00:51:20

相关推荐

  • 在C语言中需要使用长整型数据类型

    在 C 或 C++ 中,有四种不同的数据类型用于整数类型数据。这四种数据类型是short、int、long 和long long。每种数据类型占用不同的内存空间。大小在不同的体系结构和不同的操作系统中有所不同。有时 int 需要 4 个字节,有时需要 2 个字节。编译器也会发生这种情况。所以我们可以…

    2025年12月17日
    000
  • 在C语言中,pthread_self()的意思是获取当前线程的ID

    这里我们看看C语言中pthread_self()的作用是什么。pthread_self()函数用于获取当前线程的ID。该函数可以唯一标识现有的线程。但如果有多个线程,并且有一个线程完成,那么该 id 就可以重用。因此,对于所有正在运行的线程,id 都是唯一的。 示例 #include #includ…

    2025年12月17日
    000
  • 如何在C语言中计算可变数量的参数?

    在本节中,我们将了解在 C 中参数数量可变的情况下如何计算参数数量。 C 支持省略号。这用于将可变数量的参数传递给函数。用户可以使用三种不同方式之一对参数进行计数。 通过传递第一个参数作为参数计数 将最后一个参数作为 NULL 传递。 立即学习“C语言免费学习笔记(深入)”; 使用 printf()…

    2025年12月17日
    000
  • C++程序,用于计算数组元素大于其左侧所有元素且至少有K个元素在其右侧的数量

    字符串是一个对象,它表示数据字符的序列。字符串是始终表示为文本格式的数据容器。它还用于概念、比较、拆分、连接、替换、修剪、长度、实习、等于、比较、子字符串操作。使用快速排序分区算法的数组中的 K 个最大(或最小)元素。 这是一个数组 R[],其中包含 N 个不同的整数。任务是找到那个特定元素,该元素…

    2025年12月17日
    000
  • 在C语言中,fork()函数

    在本节中,我们将了解C语言中的fork系统调用。这个fork系统调用用于创建一个新的进程。这个新创建的进程被称为子进程。创建另一个子进程的当前进程被称为父进程。 子进程使用相同的程序计数器、CPU寄存器和父进程使用的相同文件。 fork()函数不接受任何参数,它返回整数值。它可能返回三种类型的整数值…

    2025年12月17日
    000
  • 在C语言中,字符串中任意两个相同字符之间的最大字符数

    我们得到一个字母字符串。数组中至少会有两个相同字符的出现。这里的任务是找到任意两个相同字符之间的最大字符数。如果没有任何字符的重复,则返回-1。 输入 – 字符串 str = “abcdba” 输出 – 字符串中任意两个相同字符之间的最大字符数 &#8…

    2025年12月17日
    000
  • 以C语言的迭代方法,将链表的最后k个节点以相反的顺序打印出来

    我们必须以相反的顺序打印链表的 k 个节点。我们必须应用迭代方法来解决这个问题。 迭代方法通常使用循环执行,直到条件值为 1 或 true。 比方说, list 包含节点 29, 34, 43, 56 和 88,k 的值为 2,输出将是直到 k 的备用节点,例如 56 和 88。 立即学习“C语言免…

    2025年12月17日
    000
  • 在C语言中,一个进程内可以创建的最大线程数

    给定的任务是在一个进程中找到可以创建的最大线程数 C. 线程是轻量级进程,可以由调度程序独立管理。因为一个线程是进程的一个组件,因此可以关联多个线程 线程相对于进程而言,不仅处理起来更轻便,而且上下文切换所需时间更短。 线程所需的资源较进程少,并且它们还与其同级共享内存。 线程。所有用户级对等线程都…

    2025年12月17日
    000
  • 使用归并排序算法编写的C/C++程序来计算数组中的逆序对数?

    对给定数组进行排序时发生的反转计数称为反转计数。逆问题是一个经典问题,可以使用归并排序算法来解决。在此问题 v 中,我们将计算其左侧大于它的所有元素,并将计数添加到输出。这个逻辑是在合并排序的合并函数中完成的。 为了更好地理解这个主题,让我们举一个例子。让我们考虑合并过程中涉及的两个子数组 &#82…

    2025年12月17日 好文分享
    000
  • 重新排列一个数组,如果在C++中,’arr’是’j’,则使’arr’变为’i’

    我们被给定一个正整数类型的数组,假设是arr[],它的大小可以任意给定,数组中的元素的值应该大于0但小于数组的大小。任务是重新排列一个数组,如果 arr[j] 是“j”,那么 arr[j] 就变成“i”并打印最终结果。 让我们看看这种情况的各种输入输出场景 – h2> 输入− in…

    2025年12月17日
    000
  • 在C语言中,malloc函数是用来动态分配内存的

    malloc()函数代表内存分配,动态分配一块内存。 它保留指定大小的内存空间,并返回指向内存位置的空指针。 malloc() 函数携带垃圾值。返回的指针是void类型。 malloc()函数的语法如下 – 立即学习“C语言免费学习笔记(深入)”; ptr = (castType*) m…

    2025年12月17日
    000
  • 使用C++按给定大小将链表分组反转

    在本文中,我们处理一个单链表,任务是以 k 为一组反转该列表。例如 – Input: 1->2->3->4->5->6->7->8->NULL, K = 3Output: 3->2->1->6->5->4-&g…

    2025年12月17日
    000
  • 在C语言中,将二叉树的右视图打印出来

    任务是打印给定二叉树的右节点。首先用户将插入数据以创建二叉树,然后打印所形成的树的右视图。 上图展示了使用节点10、42、93、14、35、96、57和88创建的二叉树,其中选择并显示在树的右侧的节点。例如,10、93、57和88是二叉树的最右节点。 示例 Input : 10 42 93 14 3…

    2025年12月17日
    000
  • 在C语言中,什么是简单断言?

    断言是一个语句,用于肯定地声明当到达该行代码时事实必须为真。 断言对于获取满足的预期条件很有用。 > 简单断言 简单断言可以通过assert(表达式)方法实现,该方法位于assert.h头文件中。 简单断言的语法如下 – 立即学习“C语言免费学习笔记(深入)”; assert(ex…

    2025年12月17日
    000
  • C++程序填充数组的特定元素

    数组是一种同质数据结构,用于在连续的内存位置中保存相似类型的数据,可以使用基地址和索引进行访问。有很多不同的应用程序中,我们使用数组来保存适用于合适用途的数据。向数组中插入元素是一种繁琐的过程之一。我们可以通过循环从用户那里获取输入来插入它们,或者从文件中插入它们,或者还有其他一些插入它们的方法。初…

    2025年12月17日
    000
  • 匿名联合体和结构体在C语言中的应用

    这里我们来看看什么是C语言中的匿名联合体和结构体。匿名联合体和结构体就是未命名的联合体和结构体。由于它们没有名称,因此我们无法创建它的直接对象。我们将其用作嵌套结构或联合。 这些是匿名联合和结构的示例。 struct { datatype variable; …};union { datatyp…

    2025年12月17日
    000
  • 计算通过交换给定数组中字符串对的第一个字符而得到的新字符串对的数量

    在这个问题中,我们需要选择一对字符串并交换它们的第一个字符。之后,我们需要计算新对的总数。我们可以通过交换每对的第一个字符并检查它是否存在于数组中来解决这个问题。 解决这个问题的高效方法是使用哈希映射数据结构。 问题陈述 – 我们有一个包含N个字符串的数组。我们可以从所有数组元素中选择任…

    2025年12月17日
    000
  • C++程序以查找数组中第二大的元素

    数组的目的是将相似类型的数据存储在一系列可以使用基地址和索引访问的内存位置中。我们在许多不同的应用程序中使用数组来保存用于各种目的的数据。查找最小和最大元素是数组的一个相当常见的示例,在包括排序等在内的多个应用程序中都需要数组。在本文中,我们将了解如何在 C++ 中从数组中查找第二大元素。 通过示例…

    2025年12月17日
    000
  • C++程序将数组转换为集合(哈希集合)

    数组是 C++ 中可用的数据结构,用于保存相同类型元素的顺序集合。数组的大小是固定的,但可以根据需要扩展或缩小。将数组视为相同类型变量的集合很重要,即使它用于存储数据集合。集合(或者在本例中为无序集合)是一种以任意顺序存储特定数据类型的元素的容器。哈希表用于实现 unordered_set,其中键被…

    2025年12月17日
    000
  • 在C/C++中,我们可以有多少级指针?

    实际上,C程序中常见的是一到两个静态级别的指针。三级间接很少见。但是无限指针间接非常常见。可以通过结构体的帮助实现无限指针间接。 struct list { struct list *next; … } lst; lst->next->next->next->…-&g…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信