前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >圆形牛棚

圆形牛棚

作者头像
浪漫主义狗
发布2023-02-21 12:00:17
1.5K0
发布2023-02-21 12:00:17
举报
文章被收录于专栏:HAUE_LYS'BlogHAUE_LYS'Blog

Original Link

思想

  • 前缀和。
  • 由于牛棚为环状,故将数组首尾相连。
  • 利用 sum 记录牛牛们需要走的距离,前缀和记录 a[i] 扇门 i ~ n 的距离。
  • 从连接后的数组开始,即 i = n ~ 2 * n 开始遍历,sum 减去后一个房间牛牛走过的距离,再加上该房间牛牛走到 i + n 的距离。
  • 维护一个最小的 ans = min(ans, sum) 即可。

代码

代码语言:javascript
复制
#include <bits/stdc++.h>
using namespace std;

typedef long long LL;

const int N = 1e6 + 3;

int a[N];

void solve(){
    int n; cin >> n;
    LL sum = 0;
    for(int i = 1; i <= n; i ++){
        cin >> a[i]; a[i + n] = a[i];
        sum += a[i] * (i - 1);
    }
    for(int i = 1; i <= 2 * n; i ++) a[i] += a[i - 1];
    LL ans = 0x3f3f3f3f;
    for(int i = n + 1; i <= 2 * n; i ++){
        sum = sum + n * (a[i] - a[i - 1]) - (a[i] - a[i - n]);
        ans = min(ans, sum);
    }
    cout << ans << endl;
}

int main(){
    solve();
    return 0;
}

本文参与 腾讯云自媒体同步曝光计划,分享自作者个人站点/博客。
原始发表:2023-2-20 2,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体同步曝光计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档