[CSP2019] 划分

link

32pts

f i , j f_{i,j} fi,j 表示最后一段分段为 [ i , j ] [i,j] [i,j] 的最小复杂度

O ( n 3 ) \mathcal O(n^3) O(n3) 转移即可

64pts

观察发现,显然有当最后一段分段的大小最小的时候答案是最优的,所以记录大小最小的大小以及这个时候的dp值就可以 O ( n 2 ) \mathcal O(n^2) O(n2) 转移了。
84pts
我们可以用单调队列维护 2 s u m i − s u m p r e i 2sum_i-sum_{pre_i} 2sumisumprei ,就可以做到 O ( n ) \mathcal O(n) O(n) 了。

100pts

高精度(__int128)

#include<iostream>
#include<cstring>
#include<cassert>
#include<cmath>
#include<map>
#include<set>
#include<queue>
#include<stack>
#include<cstdio>
#include<vector>
#include<time.h>
#include<algorithm>
#include<climits>

using namespace std;

# define Rep(i,a,b) for(register int i=a;i<=b;i++)
# define _Rep(i,a,b) for(register int i=a;i>=b;i--)
# define RepG(i,u) for(int i=head[u];~i;i=e[i].next)

typedef long long ll;

const int N=4e7+5;

template<typename T> void read(T &x){
   x=0;int f=1;
   char c=getchar();
   for(;!isdigit(c);c=getchar())if(c=='-')f=-1;
   for(;isdigit(c);c=getchar())x=(x<<1)+(x<<3)+c-'0';
    x*=f;
}

int n,type;
int a[N],pre[N];
ll sum[N];
int q[N],head,tail;
int val[105],tot;
int l,r,p;
int x,y,z,m;

int main()
{
	read(n),read(type);
	if(type){
		read(x),read(y),read(z),read(a[1]),read(a[2]),read(m);
		Rep(i,3,n)a[i]=(1ll*a[i-1]*x+1ll*a[i-2]*y+z)%(1<<30);
		int last=0;
		Rep(i,1,m){
			read(p),read(l),read(r);
			Rep(j,last+1,p)
				a[j]=a[j]%(r-l+1)+l;
			last=p;
		}
	}
	else Rep(i,1,n)read(a[i]);
	Rep(i,1,n)sum[i]=sum[i-1]+a[i];
	head=1,tail=0;
	q[++tail]=0;
	int last=0;
	Rep(i,1,n){
		while(head<=tail&&sum[q[head]]-sum[pre[q[head]]]+sum[q[head]]<=sum[i])last=q[head],head++;
		pre[i]=last;
		while(head<=tail&&sum[q[tail]]-sum[pre[q[tail]]]+sum[q[tail]]>sum[i]-sum[pre[i]]+sum[i])tail--;
		q[++tail]=i;
	}
	__int128 ans=0;
	int now=n;
	while(now)ans+=(__int128)(sum[now]-sum[pre[now]])*(sum[now]-sum[pre[now]]),now=pre[now];
	while(ans){
		val[++tot]=ans%10;
		ans/=10;	
	}
	_Rep(i,tot,1)printf("%d",val[i]);
	puts("");
	return 0;
}
  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
资源来源于网络,如有侵权,私信立删。 CSP-J/S第一轮时间 CSP-J/S第一轮分为:CSP-J1和CSP-S1。和NOIP第一轮时间一样,CSP-J/S第一轮认证在10月份第三个星期六进行。 CSP-J/S第一轮考察重点 第一轮认证为笔试或机试,主要测试选手有关计算机方面的基本知识,第一轮为资格测试。从2020年开始,全部为机试。 CSP-J/S第一轮报名方式 参加CSP-S/J两组两轮认证均须在网上注册报名,注册网站为http://rg.noi.cn。参加认证者必须如实填写个人信息报名,包括但不限于姓名、身份证号、出生日期、性别、就学(学籍学校)/就职单位等,信息一旦注册,不得修改,如有错误,责任自负。 CSP-J/S第一轮认证考点 省认证点由CCF授权的CSP非专业级别省认证组织单位设置。 1、第一轮认证点:由省认证组织单位总负责人设置,每个认证点人数不应少于20人。 2、未经批准的认证点,其认证成绩不予承认。 认证费用 第一轮CSP-S/J组:50元/人(该费用不包括食宿及交通费)。 CSP-J/S第一轮认证试题组成 CSP-J/S第一轮在10月份第三个星期六进行,其中CSP-J1认证时间为周六9:30-11:30,CSP-S1认证时间为周六14:30-16:30。考试时长为2小时,内容为笔试或机试(从2020年开始全部为机试),满分100分。 试题由三部分组成: ① 选择题(共15题,每题2分,共计30分) CSP-S1的前10道题为单选题,后10道题为不定项选择题(只有全部选对才得分,否则不得分);CSP-J1的前15道题都是单选题。 ② 程序阅读理解题(共3题,共计40分) 题目给出一段程序(不一定有关于程序功能的说明),考生通过阅读理解该段程序进行答题,分为选择题和判断题。 ③ 程序完善题(共3题,共计30分) 题目给出一段关于程序功能的文字说明,然后给出一段程序代码,在代码中略去了若干个语句或语句的一部分并在这些位置给出空格,要求考生根据程序的功能说明和代码的上下文,选择对应答案 。三题皆为选择题。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值