< 2025年1月 >
29 30 31 1 2 3 4
5 6 7 8 9 10 11
12 13 14 15 16 17 18
19 20 21 22 23 24 25
26 27 28 29 30 31 1
2 3 4 5 6 7 8

练一下斜率优化

复制代码
 1 var s1,s2,f:array[0..1000010] of int64;
 2     q,a,b:array[0..1000010] of longint;
 3     i,n,h,t,j:longint;
 4 
 5 function g(j,k:longint):double;
 6   var a,b:double;
 7   begin
 8     a:=f[j]-f[k]-s2[j]+s2[k];
 9     b:=s1[k]-s1[j];
10     exit(a/b);
11   end;
12 
13 begin
14   readln(n);
15   for i:=1 to n do
16     read(a[i]);
17   for i:=1 to n do
18   begin
19     read(b[i]);
20     s1[i]:=s1[i-1]+b[i];
21     s2[i]:=s2[i-1]+int64(b[i])*int64(n-i+1);
22   end;
23   h:=0;
24   t:=0;
25   for i:=1 to n do
26   begin
27     while (h<t) and (g(q[h],q[h+1])>=n-i+1) do inc(h);
28     j:=q[h];
29     f[i]:=f[j]+a[i]+s2[i-1]-s2[j]-(s1[i-1]-s1[j])*int64(n-i+1);
30     while (h<t) and (g(q[t],i)>=g(q[t-1],q[t])) do dec(t);
31     inc(t);
32     q[t]:=i;
33   end;
34   writeln(f[n]);
35 end.
View Code
复制代码

 

posted on   acphile  阅读(123)  评论(0编辑  收藏  举报
编辑推荐:
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· SQL Server 内存占用高分析
· .NET Core GC计划阶段(plan_phase)底层原理浅谈
· .NET开发智能桌面机器人:用.NET IoT库编写驱动控制两个屏幕
· 用纯.NET开发并制作一个智能桌面机器人:从.NET IoT入门开始
阅读排行:
· 我干了两个月的大项目,开源了!
· 推荐一款非常好用的在线 SSH 管理工具
· 聊一聊 操作系统蓝屏 c0000102 的故障分析
· 千万级的大表,如何做性能调优?
· .NET周刊【1月第1期 2025-01-05】
点击右上角即可分享
微信分享提示