简单写一下吧

emmmm,来晚了1h,没赶上,所以没交.......(捂脸

T1

开始读错题了诶

开烤1.2h后

发现是个傻逼题....

排序一下,维护前缀最左,右端点

随机数据我跑的比他们都慢..........

#include<cstdio>
#include<algorithm>
#define LL long long
const int maxn = 2000007;
struct node {
int v,loc;
} a[maxn];
bool cmp(node q,node b) {
if(q.v == b.v) return q.loc <= b.loc;
return q.v > b.v;
}
int n,m;
int main() {
freopen("w.in","r",stdin); freopen("w.out","w",stdout);
LL ans = 0; scanf("%d",&n);
for(int i = 1;i <= n;++ i) scanf("%d",&a[i].v), a[i].loc = i;
std::sort(a + 1, a + n + 1,cmp);
int l = a[1].loc,r = a[1].loc;
ans = a[1].v;
for(int i = 2;i <= n;++ i) {
int k = a[i].loc;
if(k < l) l = k;
if(k > r) r = k;
if(k >= l)ans = std::max(1ll * (k - l + 1) * a[i].v,ans);
if(k <= r)ans = std::max(1ll * (r - k + 1) * a[i].v,ans);
}
printf("%I64d\n",ans);
return 0;
}

T2

emmmm,推了一下式子

发现这个



所以只需要尽可能的合并就行了

#include <cstdio>
int cnt[10000007];
const int mod = 998244353;
#define LL long long
int main() {
freopen("s.in","r",stdin);
freopen("s.out","w",stdout);
int n;
scanf("%d",&n);
int cnt[32] = {0};
for(int i = 1;i <= n;i ++) {
int x; scanf("%d", &x);
for(int j = 0;j < 32;j ++) if(x & (1 << j)) cnt[j] ++;
}
LL ans = 0;
for(int i = 1;i <= n;i++) {
int x = 0;
for (int j = 0;j < 32;j ++) if (cnt[j]) x |= (1 << j), cnt[j] --;
ans = (ans + 1ll * x * x) % mod;
}
printf("%lld\n",ans % mod); return 0;
}

T3

状压dp

记录本行和上一行状态

然后把可行状态抽出来就行了

#include<cstdio>
#include<algorithm>
using namespace std;
#define LL long long
const int mod = 1e9 + 7;
inline int read() {
int x = 0;
char c = getchar();
while(c < '0' || c > '9')c = getchar();
while(c <= '9'&& c >= '0')x = x * 10 + c - '0',c = getchar();return x;
return x;
}
int n,m,k;
const int maxn = 17;
int cant[maxn];
bool judge(int s) {
if((s & (s >> 1)) || (s & (s >> 2))) return false;
return true;
}
int s[maxn];
int id[maxn];
int dp[maxn][407][407];
int main() {
n = read() , m= read() - 1,k = read();
for(int t,p,i = 1;i <= k;++ i) {
t = read(),p = read() - 1;
cant[t] |= (1 << p);
}
int T = (1 << m) - 1;
int cnt = 0;
for(int i = 0;i <= T;++ i)
if(judge(i)) s[++ cnt] = i,s[i] = cnt;
for(int i = 0;i <= T;++ i) dp[0][0][i] = 1;
long long ans = 0;
for(int i = 1;i <= n;++ i) {
for(int s1 = 0; s1 <= T;++ s1) {
if(cant[i] & s[s1]) continue;
for(int s2 = 0;s2 <= (i <= 1 ? 1 : T);++ s2) {
if(cant[i - 1] & s2 || ((s1 >> 1) & s2) || ((s1 << 1) & s2) || (s1 & s2)) continue;
for(int s3 = 0;s3 <= (i <= 2 ? 1 : T);++ s3) {
if((s3 & s1) || (cant[i - 2] & s3) || ((s2 >> 1) & s3) || ((s2 << 1) & s3) || (s2 & s3) ) continue;
dp[i][s2][s1] += dp[i - 1][s3][s2];
dp[i][s2][s1] %= mod;
}
if(i == n) {ans += dp[i][s2][s1],ans %= mod;}
}
}
}
printf("%lld\n",ans);
return 0;
}

R2 day2的更多相关文章

  1. 「POI2011 R2 Day2」Tree Rotations【线段树合并】

    题目链接 [BZOJ] [洛谷] [LOJ] 题解 由于是前序遍历,那么讨论一棵树上的逆序对的情况. 两个节点都在左子树上 两个节点都在右子树上 两个节点分别在不同的子树上. 前两种情况其实也可以归结 ...

  2. 1.初始Windows Server 2012 R2 Hyper-V + 系统安装详细

    干啥的?现在企业服务器都是分开的,比如图片服务器,数据库服务器,redis服务器等等,或多或少一个网站都会用到多个服务器,而服务器的成本很高,要是动不动采购几十台,公司绝对吃不消的,于是虚拟化技术出来 ...

  3. 阿里云学生优惠Windows Server 2012 R2安装IIS,ftp等组件,绑定服务器域名,域名解析到服务器,域名备案,以及安装期间错误的解决方案

     前言: 这几天终于还是按耐不住买了一个月阿里云的学生优惠.只要是学生,在学信网上注册过,并且支付宝实名认证,就可以用9块9的价格买阿里云的云服务ECS.确实是相当的优惠. 我买的是Windows S ...

  4. 【从零开始学BPM,Day2】默认表单开发

    [课程主题]主题:5天,一起从零开始学习BPM[课程形式]1.为期5天的短任务学习2.每天观看一个视频,视频学习时间自由安排. [第二天课程] Step 1 软件下载:H3 BPM10.0全开放免费下 ...

  5. windows 2012 r2 can't find kb2919355

    问题   解决: 1.手动安装了 Windows8.1-KB2919442-x64 2.手动下载 KB2919355 更新成功     Turns out to have been a result ...

  6. Windows Server 2008 R2常规安全设置及基本安全策略

    这篇文章主要介绍了Windows Web Server 2008 R2服务器简单安全设置,需要的朋友可以参考下 用的腾讯云最早选购的时候悲催的只有Windows Server 2008 R2的系统,原 ...

  7. Windows 2008 R2 安装sp1时未知错误的解决办法

    最近在为Windows Server 2008 R2 打sp1补丁时出现“发生未知错误”,详细信息错误:0x800f0818: google后找到解决问题步骤,参照:http://www.wikiho ...

  8. 如何在Windows Server 2008 R2没有磁盘清理工具的情况下使用系统提供的磁盘清理工具

    今天,刚好碰到服务器C盘空间满的情况,首先处理了临时文件和有关的日志文件后空间还是不够用,我知道清理C盘的方法有很多,但今天只分享一下如何在Windows Server 2008 R2没有磁盘清理工具 ...

  9. 在CentOS 7上安装.NET Core R2跑Hello World

    前言 在上个月.NET Core出了最新版本预览版,只是在Window系统上试验了一下.原本想等发布正式版的时候在linux系统上试试,可能还需要一段时间,刚好有空可以折腾一下. 由于之前安装的Ubu ...

随机推荐

  1. UML和模式应用4:初始阶段(2)--需求科目之进化式需求

    1. 前言 UP开发包括四个阶段:初始阶段.细化阶段.构建阶段.移交阶段: UP每个阶段包括 业务建模.需求.设计等科目: 需求是UP科目之一,在初始阶段需求科目的工作量占据较大的部分.但是初始阶段的 ...

  2. 嵌入式系统C编程之堆栈回溯

    前言 在嵌入式系统C语言开发调试过程中,常会遇到各类异常情况.一般可按需添加打印信息,以便观察程序执行流或变量值是否异常.然而,打印操作会占用CPU时间,而且代码中添加过多打印信息时会显得很凌乱.此外 ...

  3. zabbix监控短信息接口是否正常

    1.创建Web scenarios 2.创建zabbix触发器name:short_message send status is not 100 Expression:{u04zbx01.yaya.c ...

  4. 解决Android SDK下载和更新失败问题

    今天更新sdk报错如下: Failed to fetch URL http://dl-ssl.google.com/android/repository/addons_list-1.xml. 说dl- ...

  5. Go语言规格说明书 之 类型(Types)

    go version go1.11 windows/amd64 本文为阅读Go语言中文官网的规则说明书(https://golang.google.cn/ref/spec)而做的笔记,完整的介绍Go语 ...

  6. ubuntu系统下Python虚拟环境的安装和使用

    ubuntu系统下Python虚拟环境的安装和使用        前言:进行python项目开发的时候,由于不同的项目需要使用不同的资源包和相关的配置,因此创建多个python虚拟环境,在虚拟环境下开 ...

  7. 【前端】js截取or分割字符串的常见方法

    1.截取字符串 分割字符串方法 1.charAt(): 没有一种有别于字符串类型的字符数据类型,所以返回的字符是长度为 1 的字符串 例如:var str="Hello world!&quo ...

  8. CPU密集型 VS IO密集型

    CPU密集型 CPU密集型也叫计算密集型,指的是系统的硬盘.内存性能相对CPU要好很多,此时,系统运作大部分的状况是CPU Loading 100%,CPU要读/写I/O(硬盘/内存),I/O在很短的 ...

  9. react之自定义react-redux的provider、connect

    Provider // Provider把store放到context里,所有的子元素可以直接取到store import React from 'react' import PropTypes fr ...

  10. Keepalived详解之 - LVS(IPVS)管理工具ipvsadm使用指南

    ipvsadm是什么? ipvsadm是用来配置.维护或者查看Linux内核当中virtual server table的一个工具, LVS(Linux virtual server)能基于一个集群当 ...