PTA乙级1049

不能直接两重循环数据是1e5会超时

这样

#include"bitsdc++.h"
using namespace std;
const int N=1e5+10;
double a[N],s[N];
double ans;
int main()
{
    int n;
    cin>>n;
    for(int i=1;i<=n;i++)   scanf("%lf",&a[i]);
    for(int i=1;i<=n;i++)   s[i]=s[i-1]+a[i];
    for(int i=0;i<=n;i++) 
    {
        for(int j=i;j<=n;j++)
            ans+=(s[j]-s[i]);
    }
    printf("%.2lf",ans);
    return 0;
    
}

需要找数学规律

另外要注意用long double不然会有一个测试点过不了

#include"bits/stdc++.h"
using namespace std;
const int N=1e5+10;
long double a[N];
long double ans;
int main()
{
    int n;
    cin>>n;
    for(int i=0;i<=n;i++)   
    {
        scanf("%llf",&a[i]);
        ans+=(n-i)*a[i]*(i+1);
    }
    printf("%.2llf",ans);
    return 0;
    
}

posted @   cxy8  阅读(15)  评论(0编辑  收藏  举报
相关博文:
阅读排行:
· 【自荐】一款简洁、开源的在线白板工具 Drawnix
· 没有Manus邀请码?试试免邀请码的MGX或者开源的OpenManus吧
· 无需6万激活码!GitHub神秘组织3小时极速复刻Manus,手把手教你使用OpenManus搭建本
· C#/.NET/.NET Core优秀项目和框架2025年2月简报
· DeepSeek在M芯片Mac上本地化部署
点击右上角即可分享
微信分享提示