51Nod 1098 最小方差 (数论)

复制代码
复制代码
 1 #include <iostream>
 2 #include <cstdio>
 3 #include <algorithm>
 4 using namespace std;
 5 
 6 typedef long long LL;
 7 const int MAXN = 1e4+5;
 8 const LL INF = 1e15+5;
 9 LL a[MAXN], sum[MAXN], ans[MAXN];
10 
11 int main()
12 {
13     int n, m;
14     while(cin>>n>>m)
15     {
16         for(int i=1; i<=n; i++)
17             scanf("%lld",&a[i]);
18         sort(a+1, a+1+n);
19         sum[0] = ans[0] = 0;
20         for(int i=1; i<=n; i++){
21             sum[i] = sum[i-1] + a[i];           //前缀和
22             ans[i] = ans[i-1] + a[i]*a[i];      //^2的前缀和
23         }
24         double Min = INF;
25         for(int i=m; i<=n; i++){
26             double tmp = (ans[i]-ans[i-m])-1.0*(sum[i]-sum[i-m])*(sum[i]-sum[i-m]) / m;
27             if(tmp < Min)
28                 Min = tmp;
29         }
30         printf("%lld\n", (LL)Min);  //强行转不要小数点后面,防止四舍五入
31     }
32     return 0;
33 }
复制代码

 

posted @   ouyang_wsgwz  阅读(237)  评论(0编辑  收藏  举报
编辑推荐:
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· SQL Server 2025 AI相关能力初探
· Linux系列:如何用 C#调用 C方法造成内存泄露
阅读排行:
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理
· 上周热点回顾(3.3-3.9)
历史上的今天:
2017-05-05 完全背包
点击右上角即可分享
微信分享提示
评论
收藏
关注
推荐
深色
回顶
展开