博客
关于我
PAT1104 Sum of Number Segments
阅读量:337 次
发布时间:2019-03-04

本文共 835 字,大约阅读时间需要 2 分钟。

要解决这个问题,我们需要计算给定正数序列的所有可能分片的总和。分片规则是按顺序连续排列的子序列。为了高效地计算,我们可以利用每个元素在序列中的位置来确定其出现次数。

分析与思路

  • 分片规则:每个分片是按顺序连续的子序列。例如,序列 a1, a2, a3, a4 的分片包括 a1, a1, a2, a2, a2, a3, a3, a3, a4, a4 等。

  • 每个元素的出现次数

    • 每个元素作为首元素的次数等于其后面元素的数量。
    • 每个元素作为非首元素的次数等于其前面元素的数量。
  • 总出现次数:每个元素的总出现次数是其作为首元素的次数加上作为非首元素的次数。

  • 计算总和:将每个元素乘以其总出现次数,然后求和即可。

  • 解决代码

    #include 
    #include
    using namespace std;int main() { int n; cin >> n; double ans = 0; for (int i = 0; i < n; ++i) { double data; cin >> data; ans += data * (i + 1) * (n - i); cout << data << " "; } cout << endl; return 0;}

    代码解释

  • 输入处理:读取序列的长度 n 和序列元素。
  • 初始化总和 ans:用于存储所有分片的总和。
  • 遍历每个元素:对于每个元素 data,计算它在所有分片中的出现次数。
  • 计算出现次数:使用公式 (i + 1) * (n - i) 计算每个元素的出现次数。这里 i 是元素的索引(从 0 开始)。
  • 累加总和:将元素乘以其出现次数,累加到 ans 中。
  • 输出结果:打印每个元素及其对应出现次数。
  • 这个方法通过数学推导,避免了暴力枚举所有分片,确保了计算的高效性和正确性。

    转载地址:http://ddhh.baihongyu.com/

    你可能感兴趣的文章
    No 'Access-Control-Allow-Origin' header is present on the requested resource.
    查看>>
    No fallbackFactory instance of type class com.ruoyi---SpringCloud Alibaba_若依微服务框架改造---工作笔记005
    查看>>
    No module named cv2
    查看>>
    No module named tensorboard.main在安装tensorboardX的时候遇到的问题
    查看>>
    No qualifying bean of type XXX found for dependency XXX.
    查看>>
    No resource identifier found for attribute 'srcCompat' in package的解决办法
    查看>>
    Node.js 文件系统的各种用法和常见场景
    查看>>
    node.js 配置首页打开页面
    查看>>
    node.js+react写的一个登录注册 demo测试
    查看>>
    Node.js安装与配置指南:轻松启航您的JavaScript服务器之旅
    查看>>
    nodejs libararies
    查看>>
    nodejs-mime类型
    查看>>
    nodejs中Express 路由统一设置缓存的小技巧
    查看>>
    Node入门之创建第一个HelloNode
    查看>>
    NotImplementedError: Cannot copy out of meta tensor; no data! Please use torch.nn.Module.to_empty()
    查看>>
    npm run build 失败Compiler server unexpectedly exited with code: null and signal: SIGBUS
    查看>>
    npm WARN deprecated core-js@2.6.12 core-js@<3.3 is no longer maintained and not recommended for usa
    查看>>
    npm和yarn的使用对比
    查看>>
    npm报错unable to access ‘https://github.com/sohee-lee7/Squire.git/‘
    查看>>
    npm的问题:config global `--global`, `--local` are deprecated. Use `--location=global` instead 的解决办法
    查看>>