当前位置: 首页 > news >正文

LeetCode算法系列_0891_子序列宽度之和

LeetCode算法系列_0891_子序列宽度之和

题目描述

给定一个整数数组 A ,考虑 A 的所有非空子序列。

对于任意序列 S ,设 S 的宽度是 S 的最大元素和最小元素的差。

返回 A 的所有子序列的宽度之和。

由于答案可能非常大,请返回答案模 10^9+7。

示例1:

输入:[2,1,3]
输出:6
解释:
子序列为 [1],[2],[3],[2,1],[2,3],[1,3],[2,1,3] 。
相应的宽度是 0,0,0,1,1,2,2 。
这些宽度之和是 6 。

提示:

  • 1 <= A.length <= 20000
  • 1 <= A[i] <= 20000

算法

const mod = 1e9 + 7

func sumSubseqWidths(a []int) int {
    //[3,2,4,1] 和 排序后的 [1,2,3,4] 宽度之和相同

    sort.Ints(a)
    n := len(a)
    res := 0
    /**
    作为最大值出现的次数
    a[0] a[1] a[2]
    1    2    4

    [2,1,3],3作为最大值进行排列组合
    [2,3],[1,3][,2,1,3],[3]
    */
    times := 1
    for i := 0; i < n; i++ {
        //a[i]作为最大值出现的次数==a[n-1-i]作为最小值出现的次数
        res += (a[i] - a[n-1-i]) * times
        //res可能非常大,所以取模
        res %= mod
        //times可能非常大,取模
        times = (times << 1) % mod
    }
    return res
}

个人思路

  1. 子序列即部分数组元素进行排列组合形成若干数组,数组中最大值-最小值即该子数组宽度
  2. [3,2,4,1]和[1,2,3,4]的子序列不一样,但是子序列的宽度之和,是相同的
  3. 对数组排序,某子序列宽度即数组头尾元素之差
  4. 举例:数组[1,2,3,4],每个元素都可能作为某子序列的最大值,最小值,n是数组长度
  5. a[i]作为最大值,有i个元素比它小,可以形成2^i个子序列
  6. a[i]作为最小值,有n-1-i个元素比它大,可以形成2^(n-1-i)个子序列
  7. 规律:a[0]作为最大值的子序列个数==a[n-1]作为最小值的子序列个数,同理a[1]与a[n-1-1]....,即a[i]最大值与a[n-1-i]最小值次数相等
  8. 子序列宽度之和=(最大值a[i]2^i+...)-(最小值a[n-1-i]2^i...)
  9. 子序列宽度之和=(a[i]-a[n-1-i]*2^i)+......
  10. 2^i的值,依次是1,2,4,8....,会很大,所以需要 对10^9+7取模

总结

  • 解决问题,最终总是找出问题背后的数学规律

GitHub

  • 项目源码在这里
  • 笔者会一直维护该项目,对leetcode中的算法题进行解决,并写下自己的思路和见解,致力于人人都能看懂的算法

个人公众号

  • 喜欢的朋友可以关注,谢谢支持
  • 记录90后码农的学习与生活

image

相关文章:

  • python数据库mysql第二天
  • c语言:输入两个正整数 求最大公约数和最小公倍数
  • Maven依赖构建版本冲突(实战cxf asm和cglib冲突)
  • 【SublimeText】【DeleteBlankLines】使用说明
  • FTP服务器的三种用户创建(部分)
  • CentOS下的apache配置支持php
  • 洛谷P2668 斗地主
  • 使用 Traefik 的一些补充细节
  • Java 内存分配及垃圾回收机制初探
  • 密码学原理学习笔记
  • 杂谈
  • 07 numpy 一元函数
  • IBM AIX系统日志配置远程Syslog采集
  • 【跃迁之路】【585天】程序员高效学习方法论探索系列(实验阶段342-2018.09.13)...
  • css的transform属性让子元素在父元素里面垂直水平居中
  • Brief introduction of how to 'Call, Apply and Bind'
  • ES6 ...操作符
  • java中具有继承关系的类及其对象初始化顺序
  • JS笔记四:作用域、变量(函数)提升
  • JS创建对象模式及其对象原型链探究(一):Object模式
  • nginx 负载服务器优化
  • pdf文件如何在线转换为jpg图片
  • React 快速上手 - 07 前端路由 react-router
  • React-redux的原理以及使用
  • Shadow DOM 内部构造及如何构建独立组件
  • 阿里云前端周刊 - 第 26 期
  • 分享一份非常强势的Android面试题
  • 基于Android乐音识别(2)
  • 通过获取异步加载JS文件进度实现一个canvas环形loading图
  • 微信端页面使用-webkit-box和绝对定位时,元素上移的问题
  • 小程序、APP Store 需要的 SSL 证书是个什么东西?
  • 怎么将电脑中的声音录制成WAV格式
  • 《码出高效》学习笔记与书中错误记录
  • 宾利慕尚创始人典藏版国内首秀,2025年前实现全系车型电动化 | 2019上海车展 ...
  • ​Z时代时尚SUV新宠:起亚赛图斯值不值得年轻人买?
  • #if和#ifdef区别
  • #中的引用型是什么意识_Java中四种引用有什么区别以及应用场景
  • (1)(1.8) MSP(MultiWii 串行协议)(4.1 版)
  • (17)Hive ——MR任务的map与reduce个数由什么决定?
  • (MATLAB)第五章-矩阵运算
  • (附源码)ssm基于jsp的在线点餐系统 毕业设计 111016
  • (规划)24届春招和25届暑假实习路线准备规划
  • .bat批处理(八):各种形式的变量%0、%i、%%i、var、%var%、!var!的含义和区别
  • .form文件_一篇文章学会文件上传
  • .Net Framework 4.x 程序到底运行在哪个 CLR 版本之上
  • .NET/C# 推荐一个我设计的缓存类型(适合缓存反射等耗性能的操作,附用法)
  • @Mapper作用
  • [ vulhub漏洞复现篇 ] Apache APISIX 默认密钥漏洞 CVE-2020-13945
  • [.NET 即时通信SignalR] 认识SignalR (一)
  • [【JSON2WEB】 13 基于REST2SQL 和 Amis 的 SQL 查询分析器
  • [Android]使用Retrofit进行网络请求
  • [AutoSAR 存储] 汽车智能座舱的存储需求
  • [C#]C#学习笔记-CIL和动态程序集
  • [C/C++随笔] char与unsigned char区别
  • [C++] 如何使用Visual Studio 2022 + QT6创建桌面应用