码农知识堂 - 1000bd
  •   Python
  •   PHP
  •   JS/TS
  •   JAVA
  •   C/C++
  •   C#
  •   GO
  •   Kotlin
  •   Swift
  • LQ0014 求和【思维】


    题目出处:蓝桥杯2022初赛

    题目描述
    给定n个整数a[1],a[2],…,a[n],求两两相乘再相加的和,即
    S=a[1]·a[2]+a[1]·a[3]+…+a[1]·a[n]+a[2]·a[3]+…+a[2]·a[n]+…+a[n-1]·a[n]

    输入格式
    第一行为正整数n,第二行为n个整数。
    30%的数据:2≤n≤1000,1≤a[i]≤100。
    100%的数据:2≤n≤200000,1≤a[i]≤1000。

    输出格式
    输出一个数字表示答案S。

    输入样例
    4
    1 3 6 9

    输出样例
    117

    问题分析
    用暴力法来解题会超时,参见最后一个代码。
    一种解法是使用前缀和来计算,连存储数据的数组也不需要。
    另外一种解法是根据公式来计算,其要点如下:
    给定n个数,求部分两两相乘问题,需要找出其规律来,算起来就简单了。
    先求出n个整数之和,再求出这n个整数的平方和,然后用公式算一下就好了。
    具体的计算方法见程序代码。
    求和后数会变得比较大,所以要用long long类型。

    AC的解题代码(前缀和)如下:

    /* LQ0014 求和 */
    
    #include 
    
    int main()
    {
        int n, a;
        long long sum = 0, psum = 0;
    
        scanf("%d", &n);
        for (int i = 1; i <= n; i++) {
            scanf("%d", &a);
            sum += psum * a;
            psum += a;
        }
    
        printf("%lld\n", sum);
    
        return 0;
    }
    

    AC的解题代码(公式)如下:

    /* LQ0014 求和 */
    
    #include 
    
    int main()
    {
        int n, a;
        long long sum = 0, sum1 = 0;
    
        scanf("%d", &n);
        for (int i = 1; i <= n; i++) {
            scanf("%d", &a);
            sum += a;
            sum1 += a * a;
        }
    
        printf("%lld\n", (sum * sum - sum1) / 2);
    
        return 0;
    }
    

    超时的解题代码(暴力)如下:

    /* LQ0014 求和 */
    
    #include 
    
    #define N 200000
    int a[N];
    
    int main()
    {
        int n;
        long long sum = 0;
    
        scanf("%d", &n);
        for (int i = 0; i < n; i++)
            scanf("%d", &a[i]);
    
        for (int i = 0; i < n; i++)
            for (int j = i + 1; j < n; j++)
                sum += a[i] * a[j];
    
        printf("%lld\n", sum);
    
        return 0;
    }
    
  • 相关阅读:
    (附源码)计算机毕业设计SSM基于的高校在线办公系统
    Lua 支持虚函数的解决方案
    Day09-尚品汇-购物车静态组件与修改
    【逐步剖C】-第十一章-动态内存管理
    Heterogeneous Parallel Programming 异构并行编程 - UIUC伊利诺伊大学(持续更新)
    mysql数据库SQL语句大全详解(下)
    TouchGFX之文本和字体
    SGPT: GPT Sentence Embeddings for Semantic Search
    GBASE 8s cpu和共享内存配置参数
    .NET CORE 完美支持AOT 的 ORM SqlSugar 教程
  • 原文地址:https://blog.csdn.net/tigerisland45/article/details/126942864
  • 最新文章
  • 攻防演习之三天拿下官网站群
    数据安全治理学习——前期安全规划和安全管理体系建设
    企业安全 | 企业内一次钓鱼演练准备过程
    内网渗透测试 | Kerberos协议及其部分攻击手法
    0day的产生 | 不懂代码的"代码审计"
    安装scrcpy-client模块av模块异常,环境问题解决方案
    leetcode hot100【LeetCode 279. 完全平方数】java实现
    OpenWrt下安装Mosquitto
    AnatoMask论文汇总
    【AI日记】24.11.01 LangChain、openai api和github copilot
  • 热门文章
  • 十款代码表白小特效 一个比一个浪漫 赶紧收藏起来吧!!!
    奉劝各位学弟学妹们,该打造你的技术影响力了!
    五年了,我在 CSDN 的两个一百万。
    Java俄罗斯方块,老程序员花了一个周末,连接中学年代!
    面试官都震惊,你这网络基础可以啊!
    你真的会用百度吗?我不信 — 那些不为人知的搜索引擎语法
    心情不好的时候,用 Python 画棵樱花树送给自己吧
    通宵一晚做出来的一款类似CS的第一人称射击游戏Demo!原来做游戏也不是很难,连憨憨学妹都学会了!
    13 万字 C 语言从入门到精通保姆级教程2021 年版
    10行代码集2000张美女图,Python爬虫120例,再上征途
Copyright © 2022 侵权请联系2656653265@qq.com    京ICP备2022015340号-1
正则表达式工具 cron表达式工具 密码生成工具

京公网安备 11010502049817号