2022-09-09:给定一个正整数 n,返回 连续正整数满足所有数字之和为 n 的组数 。
示例 1:
输入: n = 5
输出: 2
解释: 5 = 2 + 3,共有两组连续整数([5],[2,3])求和后为 5。
示例 2:
输入: n = 9
输出: 3
解释: 9 = 4 + 5 = 2 + 3 + 4
示例 3:
输入: n = 15
输出: 4
解释: 15 = 8 + 7 = 4 + 5 + 6 = 1 + 2 + 3 + 4 + 5

答案2022-09-09:

如果有,N = (x+1) + (x+2) + … + (x+k)
上式子可以化简为:N = kx + k(k+1)/2
左右两边同时乘以2,可以得到:2N = 2kx + k^2 + k
进而得到:2N = k(2x + k + 1)
2N 偶 k * (2x + k + 1)
k 2x + k + 1
所以,对于2N = k(2x + k + 1),这个式子来说,只要给定不同的一组x和k,就对应一种不同的方案
进一步分析可以看出:
如果k为偶数,那么2x + k + 1就是奇数
如果k为奇数,那么2x + k + 1就是偶数
2N = 左 K 右 2x + k + 1
2N 奇数因子K, 2x + k + 1
也就是说,对于每一种方案,k和2x + k + 1,一定是不同的,并且连奇偶性都相反
所以2N里任何一个奇数因子,可能作为k这一项,也可能作为2x+k+1这一项,
不管奇数因子作为哪一项,都可以推出另外一项的值,进而确定k和x具体是多少
进而可以推出,2N里有多少个奇数因子,就有多少种方案
于是这个题就变成了求N里有多少奇数因子
一般来说,求N里有多少奇数因子,用O(根号N)的方法肯定可以
但其实可以更加的优化,
如果 N = 3^a * 5^b * 7^c * 9^d …那么N一共会出现多少奇数因子呢?
N的质数因子:可以选择0个3…可以选择1个3…可以选择2个3…可以选择a个3,所以有a+1种选择
上面的选择,去乘以:可以选择0个5…可以选择1个5…可以选择2个5…可以选择b个5,所以有b+1种选择
上面的选择,去乘以:可以选择0个7…可以选择1个7…可以选择2个7…可以选择c个7,所以有c+1种选择

所以,一共有(a + 1) * (b + 1) * (c + 1) * (d + 1) …这么多个奇数因子。

代码用rust编写。代码如下:

  1. fn main() {
  2. let n = 3 * 5 * 7;
  3. let ans = consecutive_numbers_sum1(n);
  4. println!("ans = {}", ans);
  5. let ans = consecutive_numbers_sum2(n);
  6. println!("ans = {}", ans);
  7. }
  8. fn consecutive_numbers_sum1(mut n: i32) -> i32 {
  9. while (n & 1) == 0 {
  10. n >>= 1;
  11. }
  12. let mut res = 1;
  13. let mut i = 3;
  14. while i <= n {
  15. let mut count = 1;
  16. while n % i == 0 {
  17. n /= i;
  18. count += 1;
  19. }
  20. res *= count;
  21. i += 2
  22. }
  23. return res;
  24. }
  25. // 进一步优化
  26. fn consecutive_numbers_sum2(mut n: i32) -> i32 {
  27. while (n & 1) == 0 {
  28. n >>= 1;
  29. }
  30. let mut res = 1;
  31. // O(根号N)
  32. let mut i = 3;
  33. while i * i <= n {
  34. let mut count = 1;
  35. while n % i == 0 {
  36. n /= i;
  37. count += 1;
  38. }
  39. // rest *= (计数+1)
  40. res *= count;
  41. i += 2
  42. }
  43. // N == 1表示已经找到了所有奇数因子
  44. // N != 1表示只残留着最后一个奇数因子了
  45. // 简单证明:如果N最后残留着不只一个奇数因子,
  46. // 比如x*y(不妨设x<y),那么在for循环里,就依然会有i*i <= N
  47. // 因为i=x时,x*x <= x*y,所以x在for循环里就能计算到
  48. // 所以如果N != 1表示只残留着一个奇数因子
  49. return if n == 1 { res } else { res << 1 };
  50. }

执行结果如下:


左神java代码

2022-09-09:给定一个正整数 n,返回 连续正整数满足所有数字之和为 n 的组数 。 示例 1: 输入: n = 5 输出: 2 解释: 5 = 2 + 3,共有两组连续整数([5],[2,的更多相关文章

  1. 算法:Manacher,给定一个字符串str,返回str中最长回文子串的长度。

    [题目] 给定一个字符串str,返回str中最长回文子串的长度 [举例] str="123", 1 str="abc1234321ab" 7 [暴力破解] 从左 ...

  2. 环形链表(给定一个链表,返回链表开始入环的第一个节点。 如果链表无环,则返回 null)

    思想: 思想:用快慢指针先判断是否有环,有环则 假设头结点到环入口距离为n,环入口到快慢指针相遇结点距离为m,则慢指针走的路程 为m+n,而快指针走的路程为m+n+k*l (k*l表示绕环走的路程), ...

  3. 给定一个奇数n,比如n=3,生成1到n平方的数,如1到9,填入九宫格,使得横竖斜的和都相等。

    对于N阶幻方,从1开始把数字从小到大按以下规则依次写入: 一.在第一行中间一列写入1 二.依次向右上方写入2.3.4...... 三.如果某数字写在了表格的某个方向外面,那就把这个数字向相反方向移动N ...

  4. 给定一个double类型的数组arr,其中的元素可正可负可0,返回子数组累乘的最大乘积。例如arr=[-2.5,4,0,3,0.5,8,-1],子数组[3,0.5,8]累乘可以获得最大的乘积12,所以返回12。

    分析,是一个dp的题目, 设f[i]表示以i为结尾的最大值,g[i]表示以i结尾的最小值,那么 f[i+1] = max{f[i]*arr[i+1], g[i]*arr[i+1],arr[i+1]} ...

  5. 给定一个只包含正整数的非空数组,返回该数组中重复次数最多的前N个数字 ,返回的结果按重复次数从多到少降序排列(N不存在取值非法的情况)

    """ #给定一个只包含正整数的非空数组,返回该数组中重复次数最多的前N个数字 #返回的结果按重复次数从多到少降序排列(N不存在取值非法的情况) 解题思路: 1.设定一个 ...

  6. JAVA 之 每日一记 之 算法( 给定一个正整数,返回它在 Excel 表中相对应的列名称。 )

    题目: 给定一个正整数,返回它在 Excel 表中相对应的列名称. 例如: 1 -> A 2 -> B 3 -> C ... 26 -> Z 27 -> AA 28 -& ...

  7. 课堂练习:给定一个十进制的正整数,写下从1开始,到N的所有整数,然后数一下其中出现“1”的个数。

    题目 1 给定一个十进制的正整数,写下从1开始,到N的所有整数,然后数一下其中出现“1”的个数. 2 要求: (1) 写一个函数 f(N) ,返回1 到 N 之间出现的“1”的个数.例如 f(12)  ...

  8. 给定一个十进制的正整数,写下从1开始,到N的所有整数,然后数一下其中出现“1”的个数。

    一.题目: n给定一个十进制的正整数,写下从1开始,到N的所有整数,然后数一下其中出现“1”的个数. n要求: n写一个函数 f(N) ,返回1 到 N 之间出现的 “1”的个数.例如 f(12)  ...

  9. 任意给定一个正整数N,求一个最小的正整数M(M>1),使得N*M的十进制表示形式里只含有1和0。

    题目:任意给定一个正整数N,求一个最小的正整数M(M>1),使得N*M的十进制表示形式里只含有1和0. 解法一:暴力求解.从1开始查找M,然后判断M*N=X这个数字是否只含有0,1. 解法二:由 ...

  10. 给定一个正整数,实现一个方法求出离该整数最近的大于自身的 换位数 <把一个整数各个数位进行全排列>

    """给定一个正整数,实现一个方法求出离该整数最近的大于自身的 换位数 -> 把一个整数各个数位进行全排列""" # 使用 permu ...

随机推荐

  1. 在MDK 5中打开MDK 4工程要注意的问题1

    我是生手,对于MDK的理解还很简单.以下内容是遇到的一种情况. 有一个MDK 4工程,要求顺序点亮4个LED灯,工程已经建好. 在MDK 5中打开,编译都没问题,要烧写时,提示"can no ...

  2. 操作kubernets(k8s)的增删改查

    资源的CRUD: 创建: Service service = client.services().inNamespace(namespace).create(service); 更新: Namespa ...

  3. Android笔记--案例:找回密码

    找回密码 具体实现: 登录成功: 报告密码不同: 报告验证码错误: 代码相关: 找回密码的界面很简单,不细说了,直接写就行 找回密码的逻辑实现: 下一次就去写数据存储啦! 拜拜!

  4. Java笔记第十三弹

    函数式接口 有且仅有一个抽象方法的接口 适用于Lambda使用的接口 @FunctionalInterface//表示函数式接口 函数式接口作为方法的参数 public class Main{ pub ...

  5. MySQL学习(十三)InnoDB

    参考博客: https://my.oschina.net/wangzemin/blog/5346534 InnoDB之BufferPool https://juejin.cn/post/7007421 ...

  6. 141. Linked List Cycle (Easy)

    ps:能力有限,若有错误及纰漏欢迎指正.交流 Linked List Cycle (Easy) https://leetcode.cn/problems/linked-list-cycle/descr ...

  7. 关于EasyExcel的数据导入和单sheet和多sheet导出

    读写Excel基本代码 直接复制不一定能用 实体类 @ExcelIgnore 在导出操作中不会被导出 @ExcelProperty 在导入过程中 可以根据导入模板自动匹配字段, 在导出过程中可用于设置 ...

  8. NIM游戏/SG函数

    NIM游戏 先看一下一维 NIM游戏. 有一堆大小为 \(n\) 的石子,甲和乙轮流从石堆里面拿石子,不能一次拿掉所有石子,取走最后一个石子的人获胜,甲先开始,谁是必胜的? 显然,谁先手,谁就获胜.那 ...

  9. OWASP TOP 10 2021

    OWASP TOP 10 2021 2021 年的 TOP 10 中有 3 个新类别.4 个更改了名称和范围的类别以及一些合并. A01. 失效的访问控制 Broken Access Control ...

  10. 二进制安装Kubernetes(k8s) v1.24.1 IPv4/IPv6双栈 --- Ubuntu版

    二进制安装Kubernetes(k8s) v1.24.1 IPv4/IPv6双栈 --- Ubuntu版本 Kubernetes 开源不易,帮忙点个star,谢谢了 介绍 kubernetes二进制安 ...