T1



啥啥啥,T1又又又爆了,整个人精神状态 良好。

解题思路

考虑数据保证任意两个房子不重合

建一个结构体存两边

最后判断一下

\(>t\) 加两个

\(==t\) 加一个

== 但是!!!!,没有排序!!喜提5分 ==

/*
刚刚写思路咋卡退了??
考虑数据保证任意两个房子不重合
建一个结构体存两边
最后判断一下
>t加两个
==t加一个
*/
#include<bits/stdc++.h>
using namespace std;
#define N 300000
int x[N],a[N],n,t;
struct nod{
double l,r;
}f[N];
bool cmp(nod a,nod b){
return a.l<b.l;
}
int main(){
freopen("house.in","r",stdin);
freopen("house.out","w",stdout);
scanf("%d%d",&n,&t);
for(int i=1;i<=n;i++){
scanf("%d%d",&x[i],&a[i]);
}
for(int i=1;i<=n;i++){
f[i].l=x[i]-(a[i]/2.0);
f[i].r=x[i]+a[i]/2.0;
}
sort(f+1,f+1+n,cmp);
int ans=2;
for(int i=1;i<n;i++){
if((f[i+1].l-f[i].r)>t) ans+=2;
if((f[i+1].l-f[i].r)==t) ans++;
}
printf("%d",ans);
return 0;
}

T2



考虑暴力时间复杂度 \(O(n^2k)\) ,

由于是环,于是破环为链。

从头到尾扫一遍。、

6 4

2 2 1 3 3 1

3 2 4 11

很遗憾没有想出 \(O(nk)\) 的正解,因为我状态转移不了。

写了个模拟退火,感觉跑的还挺快

喜提25分

又细想了一下双指针做法,但是感觉实现起来很困难。

T4



看到题目暴力就有了,写一个 get 函数,然后从1枚举到 R,看是否符合条件。

ULL get(ULL m){
ULL sum=0;
while(m!=0){
sum+=m%10;
m=m/10;
}
return sum;
}

比赛时捞了45分。

然后尝试打表暴力优化,然而好像极限是55分,\(1e18\) 过于强悍。

for(int i=0;i<=1e6;i++){
if(i%10==0)
biao[i]=get(i);
else biao[i]=biao[i-1]+1;
}
for(int i=1;i<=R;i++){
if(i*k<=1e6){
if(biao[i]==biao[i*k]) ans++;
}
else{
if((biao[i/1000000]+biao[i%1000000])==(biao[i*k/1000000]+biao[(i*k)%1000000])) ans++;
}
}

思考正解数位 DP,

设 \(dp[i][0/1][j][p][t]\) 表示填到了第 i 位,卡不卡上界,\(f(x)=j\) ,\(f(k×x)=p\) (不计算最高位),需要向最高位进 t 的 x 有多少个。

所以这个 0/1 就表示后面的 i 为和 R 后 i 位的大小关系,如果填的数大于 R 后 i 为,那么这个状态就是1;否则就是0

至于转移,就比较简单,我们枚举这一位上填什么数y,那么对于x,数位和增加了y,对于 \(k×x\),这一位上直接来一个乘法是 \(k×y\),还有之前的进位 t,于是就是 \((k×y+t)%10\),新的进位就是 \((k×y+t)/10\)。

最后的答案就是 \(∑idp[lgR][0][i][i][0]\),我们把 \(j−p\) 看成一维状态就好了

AC代码:

#include<bits/stdc++.h>
#define re register
#define LL long long
LL dp[25][2][1000][500];
int m,w,a[25],M=250;LL n;
inline void split(LL x) {
while(x) a[++w]=(x%10),x/=10;
}
int main() {
freopen("number.in","r",stdin);
freopen("number.out","w",stdout);
scanf("%lld%d",&n,&m);
dp[0][0][0][M]=1;
split(n);
for(re int i=0;i<w+3;i++)
for(re int j=0;j<2;++j)
for(re int k=0;k<1000;++k)
for(re int p=M-2*i*9;p<=M+2*i*9;++p) {
if(!dp[i][j][k][p]) continue;
for(re int t=0;t<10;++t)
dp[i+1][t==a[i+1]?j:t>a[i+1]][(k+t*m)/10][p+t-(k+t*m)%10]+=dp[i][j][k][p];
}
printf("%lld\n",dp[w+3][0][0][M]-1);
return 0;
}

SXYZ-7.3训练赛的更多相关文章

  1. 10.0.0.55_12-16训练赛部分writeup

    0x1 - MISC MISC100 一张帅行的照片 目测是图片隐写,但是binwalk并没有出来,应该是对文件头进行了修改 010editor查看一下,发现在jpg文件尾之后还有大量的数据 而且在灰 ...

  2. Contest1592 - 2018-2019赛季多校联合新生训练赛第二场(部分题解)

    Contest1592 - 2018-2019赛季多校联合新生训练赛第二场 D 10248 修建高楼(模拟优化) H 10252 组装玩具(贪心+二分) D 传送门 题干 题目描述 C 市有一条东西走 ...

  3. Contest1585 - 2018-2019赛季多校联合新生训练赛第一场(部分题解)

    Contest1585 - 2018-2019赛季多校联合新生训练赛第一场 C 10187 查找特定的合数 D 10188 传话游戏 H 10192 扫雷游戏 C 传送门 题干: 题目描述 自然数中除 ...

  4. 7.30 正睿暑期集训营 A班训练赛

    目录 2018.7.30 正睿暑期集训营 A班训练赛 T1 A.蔡老板分果子(Hash) T2 B.蔡老板送外卖(并查集 最小生成树) T3 C.蔡老板学数学(DP NTT) 考试代码 T2 T3 2 ...

  5. HDU6578 2019HDU多校训练赛第一场 1001 (dp)

    HDU6578 2019HDU多校训练赛第一场 1001 (dp) 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6578 题意: 你有n个空需要去填,有 ...

  6. HDU6579 2019HDU多校训练赛第一场1002 (线性基)

    HDU6579 2019HDU多校训练赛第一场1002 (线性基) 传送门:http://acm.hdu.edu.cn/showproblem.php?pid=6579 题意: 两种操作 1.在序列末 ...

  7. 2018牛客网暑假ACM多校训练赛(第三场)I Expected Size of Random Convex Hull 计算几何,凸包,其他

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-I.html 题目传送门 - 2018牛客多校赛第三场 I ...

  8. 2018牛客网暑假ACM多校训练赛(第三场)G Coloring Tree 计数,bfs

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-G.html 题目传送门 - 2018牛客多校赛第三场 G ...

  9. 2018牛客网暑假ACM多校训练赛(第三场)D Encrypted String Matching 多项式 FFT

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round3-D.html 题目传送门 - 2018牛客多校赛第三场 D ...

  10. 2018牛客网暑假ACM多校训练赛(第二场)E tree 动态规划

    原文链接https://www.cnblogs.com/zhouzhendong/p/NowCoder-2018-Summer-Round2-E.html 题目传送门 - 2018牛客多校赛第二场 E ...

随机推荐

  1. LOTO示波器功率分析功能

    LOTO示波器软件在非标功能中增加了功率分析功能,对当前屏幕的电压波形和电流波形进行了瞬时功率,视在功率以及有功功率/平均功率的分析计算. 有功功率是指电器所消耗的电能,用于产生热能.机械能或光能等, ...

  2. RESTful服务与swagger

    一开始刚学springboot的时候 restful服务+swagger一点都看不懂,现在知识学了一些,再回头看这些东西就简单很多了. 自己跟视频做了一个零件项目,里面写了一些零零散散的模块,其中在视 ...

  3. 【H5】02 <head>头标签介绍

    摘自: https://developer.mozilla.org/zh-CN/docs/Learn/HTML/Introduction_to_HTML/The_head_metadata_in_HT ...

  4. 【DataBase】MySQL 12 SQL函数 聚合函数

    视频参考自:P53 - P58 https://www.bilibili.com/video/BV1xW411u7ax 什么是分组函数? 用来统计使用,其具体的实现都是基于对字段的值聚合再处理 又称为 ...

  5. 树莓派3B+ 安装开源软路由 openwrt 并设置 无线网桥

    在openwrt官网上找到最新版的下载地址: https://openwrt.org/releases/19.07/start 注:   本文中使用的openwrt 系统为最新的稳定版系统,自带web ...

  6. 向日葵的平替:fastnat的使用

    相关: 向日葵的平替:一款个人开发的远程工具--fastnat ---------------------------------------------- 1. 下载安装 2. 注册设备 我这里在两 ...

  7. [CEOI2007] 树的匹配 Treasury 题解

    前言 题目链接:洛谷. 题目简述 给一棵树,问你这棵树的最大匹配是多少,并且计算出有多少种最大匹配. 题目分析 先来考虑较简单的最大匹配数.对于某一个结点,它有以下三种状态: 不参与匹配: 和某一个儿 ...

  8. [rCore学习笔记 023]任务切换

    导读 还是要先看官方手册. 学过DMA的同志可能比较好理解,一句话, 释放CPU总线 : 如果把应用程序执行的整个过程进行进一步分析,可以看到,当程序访问 I/O 外设或睡眠时,其实是不需要占用处理器 ...

  9. Sealos 就是小团队的神器

    作者:阳明.Kubernetes 布道师,公众号 K8s 技术圈主理人 最近我们新开发了一个项目 fastclass.cn,这个项目是一个独立开发者的学习网站,我们的目标是帮助你使用 Figma.Py ...

  10. springboot经验之sql注入、xss注入拦截(POST)

    简介 sql注入.xss注入.cors攻击的简介以及解决方案,可以参考下面链接: https://blog.csdn.net/yhhyhhyhhyhh/article/details/84504487 ...