两两乘积之和

两两乘积之和

集合X = {a, b, c}的成对乘积可以定义为所有可能的集合对乘积的。集合的成对为Y = {a * a, a * b, a *c, b * b, b * c, c * c},其中乘积是可交换的。因此,集合X的成对乘积是集合Y的元素之和,即aa + ab + ac + bb + bc + cc。

在数学术语中,可能的配对乘积的总和可以表示为:

$$mathrm{displaystylesumlimits_{i=1,j=i}^{ileq n,jleq n}:(i,j)=itime j}$$

问题陈述

给定一个数字n。在范围(1,n)内,包括n和1,找到成对乘积的总和。

示例示例1

Input: n = 4
Output: 65

Explanation

的中文翻译为:

解释

i的范围从1到4,j的范围从i到4。

1*1 + 1*2 + 1*3 + 1*4 + 2*2 + 2*3 + 2*4 + 3*3 + 3*4 + 4*4 = 1 + 2 + 3 + 4 + 4 + 6 + 8 + 9 + 12 + 16 = 65

示例示例2

Input: n = 10
Output: 1705

Explanation

的中文翻译为:

解释

i的范围从1到10,j的范围从i到10。

1*1 + 1*2 + … + 1*10 + 2*2 + 2*3 + … + 2*10 + 3*3 + 3*4 + … + 3*10 + 4*4 + 4 *5 + … 4*10 + 5*5 + 5*6 + … + 5*10 + 6*6 + 6*7 + … 6*10 + 7*7 + 7*8 + … 7*10 + 8* 8 + 8*9 + 8*10 + 9*9 + 9*10 + 10*10 = 1705

方法一:暴力破解方法

解决这个问题的蛮力解法是使用两个for循环迭代范围内的所有可能的数对,其中第一个循环从1到n迭代,第二个循环从第一个数迭代到n。

伪代码

procedure pairwiseProduct (n)   sum = 0   for i = 1 to n      for j = i to n         sum = sum + (i * j)end procedure

示例:C++实现

在以下程序中,我们找到所有可能的配对,然后找到乘积的和。

#include using namespace std;// Function to find pairwise product over the range 1 to n, 1 and n inclusiveunsigned long long pairwiseProduct(unsigned int n){   unsigned long long sum = 0;      // First number: 1 <= i <= n   for (unsigned int i = 1; i <= n; i++){         // Second number: i <= j <= n      for (unsigned int j = i; j <= n; j++){         sum += i * j;      }   }   return sum;}int main(){   unsigned long long n = 9;   cout << "Pairwise Product = " << pairwiseProduct(n);   return 0;}

输出

Pairwise Product = 1155

时间复杂度 – O(n^2)

空间复杂度 – O(1)

方法二

以n = 4为例,

I = 1*1 + 1*2 + 1*3 + 1*4 + 2*2 + 2*3 + 2*4 + 3*3 + 3*4 + 4*4

在简化上述内容时,

I = 1*1 + (1+2)*2 + (1+2+3)*3 + (1+2+3+4)*4

取prefix_sum[1] = 1,

前缀总和[2] = 1+2,

前缀总和[3] = 1+2+3,

前缀总和[2] = 1+2,

伪代码

procedure pairwiseProduct (n)   sum = 0   prefixSum = 0   for i = 1 to n      prefixSum = prefixSum + 1      sum = sum + i * prefixSumend procedure

示例:C++实现

在下面的程序中,我们找到每次迭代的和,即前缀和,并乘以迭代次数,然后在每一步中加到最终和中。

#include using namespace std;// Function to find pairwise product over the range 1 to n, 1 and n inclusiveunsigned long long pairwiseProduct(unsigned int n){   unsigned long long sum = 0;   unsigned long long prefixSum = 0;   for (unsigned int i = 1; i <= n; i++){      prefixSum += i;      sum += i * prefixSum;   }   return sum;}int main(){   unsigned long long n = 9;   cout << "Pairwise Product = " << pairwiseProduct(n);   return 0;}

输出

Pairwise Product = 1155

结论

总之,对于在范围1到n内的数字的两两乘积之和的求解,我们可以采用上述两种方法之一,其中第一种方法是暴力法,时间复杂度为O(n^2),第二种方法是使用前缀和来计算两两乘积之和的优化方法,时间复杂度为O(n)。

以上就是两两乘积之和的详细内容,更多请关注创想鸟其它相关文章!

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

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月17日 22:03:17
下一篇 2025年12月17日 22:03:24

相关推荐

  • 关于如何解决css3中calc在less编译时被计算的办法

    这篇文章主要介绍了浅谈css3中calc在less编译时被计算的解决办法的相关资料,内容挺不错的,现在分享给大家,也给大家做个参考。 对于前端er来说,Less或Sass已经是一项必备的基本技能,有了这个利器,可以省下前端开发者的很多编码时间,让你写CSS如行云流水一般,然后最近我在Less里加入c…

    好文分享 2025年12月24日
    000
  • 如何使用CSS3中的calc()属性来表达尺寸

    这篇文章主要介绍了关于如何使用css3中的calc()属性来表达尺寸,有着一定的参考价值,现在分享给大家,有需要的朋友可以参考一下 calc()的用法十分巧妙,可以像我们在学校做数学应用题那样列式子来计算长度宽度等值,从而一定程度上实现自适应布局,下面我们就来介绍如何使用CSS3中的calc()属性…

    好文分享 2025年12月24日
    000
  • 计算一个数的阶乘中末尾零的个数的C/C++编程?

    计算阶乘数中末尾零的个数是通过计算该数的因子中2和5的个数来完成的。因为2*5等于10,而10是阶乘数中的末尾零。 示例 7的阶乘=5040,末尾0的个数为1。 根据我们的逻辑,7!=2*3*4*5*6*7,它有3个2和1个5,所以末尾0的个数为1。 #include using namespace…

    2025年12月17日
    000
  • 计算最大公因数的C++程序

    最高公因数或最大公约数是能够在不产生任何余数的情况下,能够同时整除两个或多个值的因数。在本文中,我们将讨论在C++中执行两个数字的HCF / GCD的几种方法。 这只是一个数学解决方案,有几种算法可以找到最大公约数。欧几里得方法是常见的找到最大公约数的方法。我们将在迭代模式和递归模式下使用相同的算法…

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

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

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

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

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

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

    2025年12月17日
    000
  • C++程序用于计算使数字n变为1所需的最小操作次数

    假设我们有一个数字n。我们任意执行这些操作之一 – 当 n 可被 2 整除时,将 n 替换为 n/2 当 n 可被 3 整除时,将 n 替换为 2n/3 当 n 可被 5 整除时,将 n 替换为 4n/5 立即学习“C++免费学习笔记(深入)”; li> 我们必须计算出数字 1 所…

    2025年12月17日
    100
  • C++程序:计算使所有礼物数量相等的操作次数

    假设我们有两个数组 A 和 B,每个数组的大小为 n。有n份礼物,我们想把它们送给一些孩子。第 i 份礼物有 A[i] 颗糖果和 B[i] 个橙子。在一次移动过程中,我们可以选择一些礼物并执行以下操作之一 – 从该礼物中取出一颗糖果(如果有); p> 从这份礼物中取出一颗橙子(如果…

    2025年12月17日
    000
  • C程序用于计算等比数列的第N项

    Given ‘a’ the First term, ‘r’ the common ratio and ‘n’ for the number of terms in a series. The task is to find the nth term of the series. So, before…

    2025年12月17日
    000
  • 如何使用指针在C语言中计算数组元素的总和?

    指针是一个存储其他变量地址的变量。 考虑以下语句 – int qty = 179; 声明指针 h2> 声明指针的语法如下 – int *p; 这里,’p’是一个指针变量,它保存其他变量的地址。 立即学习“C语言免费学习笔记(深入)”; 指针的初始…

    2025年12月17日
    000
  • 打印n个数字,使它们的和是一个完全平方数

    给定n个数字,程序必须找到这n个数字的和为一个完全平方数 Input : 5Output : 1 3 5 7 91+3+5+7+9=25 i.e (5)^2 算法 START Step 1 : Declare a Macro for size let’s say of 5 and i t…

    2025年12月17日
    000
  • 使用C++编写,在矩阵中找到给定和的一对数字

    在本文中,我们将讨论在给定矩阵中查找具有给定和的对的程序。例如 – Input : matrix[n][m] = { { 4, 6, 4, 65 }, { 56, 1, 12, 32 }, { 4, 5, 6, 44 }, { 13, 9, 11, 25 } }, SUM = 20Out…

    2025年12月17日
    000
  • 前n个自然数的平方和的和

    前 n 个自然数的平方和是求最多 n 项的平方和。本系列求 n 以内每个数字的和,并将该和添加到 sum 变量中。 前 4 个自然数的平方和之和为 – sum = ( 12) + (12 + 22 ) + (12 + 22 + 32) + (12 + 22 + 32 + 4 2 ) = …

    2025年12月17日
    000
  • 如何在C语言中计算浮点数中的位数?

    在此问题中,给出了一个浮点值。我们必须找到它的二进制表示中的设置位的数量。 例如,如果浮点数是0.15625,则有六个设置位。典型的 C 编译器使用单精度浮点表示。所以它看起来像这样。 要转换为位值,我们必须将数字放入一个指针变量中,然后将指针强制转换为 char* 类型数据。然后对每个字节进行一一…

    2025年12月17日
    000
  • C++程序计算矩阵对角线之和

    The utilization of 2-dimensional arrays or matrices is extremely advantageous for severalapplications. Matrix rows and columns are used to hold number…

    2025年12月17日
    100
  • 计算给定值的以10为底的对数的C++程序

    各种应用中的自然计算相对需要以 10 为底的对数。对于竞争性考试,有一些快速方法可以记住一些日志值。在编程时,有几种使用库函数计算对数结果的方法以及一些快捷方式。在这篇文章中,我们将介绍几种在 C++ 中计算给定数字的以 10 为底的对数的方法。 使用 log10() 函数 用于确定给定参数的以 1…

    2025年12月17日
    000
  • 计算三个不重叠的子字符串,将它们连接起来形成一个回文串

    简介 在本教程中,我们将详细阐述一种从给定字符串 s 中查找三个不重叠子字符串的方法,并且当所有子字符串组合在一起时,它们形成一个回文。为了解决此任务,我们使用 C++ 编程语言的字符串类功能。 字符串中的回文表示该字符串在向前和向后方向上读起来都相同。回文字符串示例是 Madam。 假设有一个字符…

    2025年12月17日
    000
  • 使用M的数字,最大计数为N,其中2和5以及6和9可以互相视为相同

    Max count是一个可能的最大计数。在这里,我们给出了一个整数N和一个整数M的字符串。我们的任务是使用整数M的数字来组成数字N,并返回最大计数。同时,我们可以将2和5视为同一个数字,将6和9视为同一个数字。 样例示例 输入 1 N = 29M = “2569783”Output 1: 2 解释 …

    2025年12月17日
    000
  • 计算不具有给定前缀的N位数字的数量

    这里的问题是确定长度为N的字符串中包含的字符’0’到’9’的总数,提供一个整数N和一个字符串前缀数组pre[],使得这些字符串中没有任何一个包含提供的前缀。本文的目的是实现一个程序,找到不具有给定前缀的N位数的数量。 在C编程语言中,一组不同的字符串被…

    2025年12月17日
    000

发表回复

登录后才能评论
关注微信