清北-Day5-R2-divide
题目描述
问是否可以将一个仅由0~9组成的字符串划分成两个或两个以上部分,使得每一部分的数字总和相等。
输入
输入文件名为 \(divide.in\)
多组数据,第一行一个数\(n\),表示数据组数
接下来\(n\)行,每行包含一个字符串
输出
输出文件名为\(divide.out\)
输出n行,每行为 \(’YES’\) 或者 \(’NO’\) ,表示是否存在题目要求的划分方案。
样例输入
3
1248
2680
54174760
样例输出
NO
YES
YES
提示
【数据说明】
对于50%的数据,$ 2 \le Length \le 100 $
对于100%的数据,$ 1 \le n \le 5 , 2 \le Length \le 10^5 $
啊,这个题,我一直以为挺难的,是个DP,结果后来发现枚举就行.....当时心里那个mmp
枚举就简单了啊
我是枚举分成多少段,然后在原数列中去 $ check $ 是否可行,至于每一段的和,直接用总和作除法就行了
当然,如果说根本无法分成当前枚举到的段数,那么直接 $ continue $
否则就一直凑就行了,每一段的和我是维护前缀和然后 \(\Theta(1)\) 求的,这个题总体比较简单,毕竟是 CF Div2 的 C题改过来的,也不是很难
至于代码.....如下吧:
#include <iostream>
#include <cstring>
#include <cstdlib>
#include <cstdio>
#define LL long long
const int N = 1e5 + 5 ;
LL T , sum[N] ;
char s[N] ;
bool f ;
inline LL read(){
LL x = 0 , f = 1 ;char ch = getchar ();
while ( ch < '0' || ch > '9' ){if ( ch == '-' ) f = - 1 ;ch = getchar ();}
while ( ch >= '0' && ch <= '9' ){x = ( x << 3 ) + ( x << 1 ) + ( ch ^ 48 ) ;ch = getchar () ; }
return f * x ;
}
int main(){
T = read (); sum[0] = 0 ;
while ( T -- ){
scanf ("%s" , s + 1 ) ; f = false ;
register int L = strlen ( s + 1 ) ;
for ( int i = 1 ; i <= L ; ++ i)
sum [i] = sum [ i - 1 ] + s[i] - '0' ;
if ( sum[L] == 0 ) { puts("YES") ; continue ;}
for ( int i = 2 ; i <= sum[L] ; ++ i){ // 枚举分成多少段
if ( sum[L] % i ) continue ; // 连整除都做不到还要你作甚
register int tmp = sum[L] / i , k = 0 ; // tmp是每段的和 , k是当前是第几段
if ( tmp == sum[L] ) continue ;
for (int j = 1 ; j <= L ; ++ j){
if ( sum[j] - k * tmp == tmp ) ++ k ; // 如果当前枚举到的子段和恰好与枚举的和相等,继续推进
else if ( sum[j] - k * tmp > tmp ) break ;// 否则,如果比当前枚举的和大,那么直接跳过,不鸟他
}
if ( k == i ) { f = true ; break ;}
}
if ( f ) puts ("YES");
else puts ("NO");
}
return 0;
}
清北-Day5-R2-divide的更多相关文章
- 清北Day4
版权声明:如需转载请标明出处,未得到本人许可请勿转载. 今天就可以看到传说中的 数据结构 嘿嘿嘿嘿 都有什么呢 链表 队列 栈 st表 hash 线段树 树链剖分 一.栈: 放出来这个看烂了的图 值得 ...
- 清北学堂2017NOIP冬令营入学测试P4745 B’s problem(b)
清北学堂2017NOIP冬令营入学测试 P4745 B's problem(b) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试 描述 题目描 ...
- 清北学堂2017NOIP冬令营入学测试 P4744 A’s problem(a)
清北学堂2017NOIP冬令营入学测试 P4744 A's problem(a) 时间: 1000ms / 空间: 655360KiB / Java类名: Main 背景 冬令营入学测试题,每三天结算 ...
- 清北Day 2
清北第二天,感受到了来自这个世界的不友善,大概把没听过不会的"名词"记录下来就已经一面了,然后被大佬说这都是最基础的东西,就很皮,那就趁别人练习字符串的题的时候,来写波博客了,倒不 ...
- 济南清北学堂游记 Day 1.
快住手!这根本不是暴力! 刷了一整天的题就是了..上午三道题的画风还算挺正常,估计是第一天,给点水题做做算了.. rqy大佬AK了上午的比赛! 当时我t2暴力写挂,还以为需要用啥奇怪的算法,后来发现, ...
- 清明培训 清北学堂 DAY1
今天是李昊老师的讲授~~ 总结了一下今天的内容: 1.高精度算法 (1) 高精度加法 思路:模拟竖式运算 注意:进位 优化:压位 程序代码: #include<iostream>#in ...
- 清北省选 DAY last 集锦
这是题目描述的链接: http://lifecraft-mc.com/wp-content/uploads/2018/03/problems1.pdf (虽然这次没去清北,但还是厚颜无耻的做了一下这套 ...
- 2017.10.1 国庆清北 D1T1 zhx的字符串题
题目背景 2017国庆清北D1T1 题目描述 你是能看到第一题的 friends 呢. ——hja 何大爷对字符串十分有研究,于是天天出字符串题虐杀 zhx.何大爷今天为 字符串定义了新的权值计算方法 ...
- 7月清北学堂培训 Day 3
今天是丁明朔老师的讲授~ 数据结构 绪论 下面是天天见的: 栈,队列: 堆: 并查集: 树状数组: 线段树: 平衡树: 下面是不常见的: 主席树: 树链剖分: 树套树: 下面是清北学堂课程表里的: S ...
- 清北考前刷题day5早安
/* C(n,k) */ #include<iostream> #include<cstdio> #include<cstring> #define ll long ...
随机推荐
- 【北航软件工程】Alpha阶段前端页面编写及服务器部署
前端页面编写 虽然之前对html语法有过一些了解,但是完全没有编写前端页面的经验,和我合作的czy大概也是这么个情况.在Alpha阶段的前端页面编写过程中,我们是摸着石头过河,html是个入门很快专精 ...
- Mysql数据的增删改查
一 介绍 MySQL数据操作: DML 在MySQL管理软件中,可以通过SQL语句中的DML语言来实现数据的操作,包括 使用INSERT实现数据的插入 UPDATE实现数据的更新 使用DELETE实现 ...
- Java语法----Java中equals和==的区别
[正文] 平时在学Android和Java语言的时候,总是碰到“equals”和“==”这两个字符,老感觉差不多:其实还是有一些区别的,今天干脆把它们彻底弄清楚. 一.java当中的数据类型和“==” ...
- heapsort(Java)(最小堆)
public static void main(String[] args) { Scanner input = new Scanner(System.in); int n = input.nextI ...
- PS图片后期之超简易造光调色方法
技法是死的,而人是活的,说的简单一点就是我们要学会开拓一下思维,调色的方法并不是只有[可选颜色]而已. 在修片之前,我们先要学会分析,在拍摄这一组照片时我希望有一种夕阳的光穿透晒在脸庞的感觉,而左边的 ...
- vue通过自定义指令 v-py 将名字转拼音
自定义指令 py: 1.新建 vue-py.js文件 import Vue from 'vue'; var chinesePointCode = { "a": [21834, 38 ...
- 【Android O】 Service AAA does not have a SELinux domain defined
在init.AAA.rc里面添加了一个脚本启动的服务: service AAA /vendor/bin/sh /vendor/etc/AAA_spec.sh user root group root ...
- jmeter笔记(3)--响应结果中文乱码的解决方式
1.举例 新建HTTP请求访问百度首页,响应结果如下: 2.原因 Jmeter安装目录/bin/jmeter.properties中sampleresult.default.encoding默认为IS ...
- 给react-native添加图标和启动屏
react native 项目默认是没有图标,并且启动页面只有文字.这个样子并不能算是一个完整的APP,现在就给APP加一个图标和一个适应所有屏幕尺寸的启动图,并且设置启动图遮住项目启动时候的白色闪屏 ...
- 二.django项目环境搭建
Ⅰ.web框架介绍 1.socket 服务端 1)客户端(手机中各种app.浏览器)是用来与服务端(网站的服务器程序)进行交互的 2)服务端类似发电厂,客户端类似电器,socket类似插座,互联网的数 ...