HDU 5355 Cake
更新后的代码:
今天又一次做这道题的时候想了非常多种思路
最后最终想出了自觉得完美的思路,结果却超时
真的是感觉自己没救了
最后加了记忆化搜索,AC了
好了先说下思路吧。不知道大家住没注意m<=10
我们能够把大部分的数据写成成对的形式比如n=27 m=6的这组数据
第1份 27 16
第2份 26 17
第3份 25 18
第4份 24 19
第5份 23 20
第6份 22 21
剩下1~15搜索出6等份分给全部人
这样成对出现的数蛇形数我们去处尽量多的偶数条
保证剩下的数的个数大于等于2*m小于4*m个
所以剩下的小于4m(小于40)个数我们仅仅解用搜索就好了
所以n 的范围就变成1~40,m的范围1~10这样我们记录这些的结果(防止这种数据大量反复出现)
这样假设我们有数据15 6计算过后
n=27 m= 6
n=39 m=6
n=15+(随意被的12) m=6
我们都不须要搜索了
就这样这个问题就攻克了
- #include<algorithm>
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<vector>
- #define maxn 100005
- #define ll __int64
- #define cnm c[nu][m]
- using namespace std;
- int v[15][maxn];
- ll m,n;
- //fun函数定义将1-num平均分给l-r个人
- int a[15][50];
- int si[15];
- bool b[50];
- int dp[50][10]={0};
- int c[50][10][15][50]={0};
- ll ave,nu;
- bool dfs(int sum,int g,int s){
- if(sum==ave){g++;sum=0;s=1;}
- if(g==m-1){
- for(int i=1;i<=nu;i++)
- if(!b[i])a[g][++a[g][0]]=i;
- return true;
- }
- for(int i=s;i<=nu;i++){
- if(sum+i>ave) return false;
- if(!b[i]){
- b[i]=true;
- a[g][++a[g][0]]=i;
- if(dfs(sum+i,g,i+1)) return true;
- b[i]=false;
- a[g][0]--;
- }
- }
- return false;
- }
- bool fun(ll num){
- if(num>=4*m-1){
- for(int i=0,j=0;i<m;i++,j++){
- v[i][si[i]++]=num-j;
- v[i][si[i]++]=num-2*m+1+j;
- }
- return fun(num-2*m);
- }
- else {
- nu=num;
- ave=(num+1)*num/2/m;
- int b;
- if(dp[num][m]==0){
- if(dfs(0,0,1)){
- dp[num][m]=1;
- for(int i=0;i<m;i++)
- for(int j=0;j<=a[i][0];j++)
- cnm[i][j]=a[i][j];
- }
- else dp[num][m]=-1;
- }
- if(dp[nu][m]==1) return true;
- return false;
- }
- }
- void out(int n){
- printf("YES\n");
- for(int i=0;i<n;i++){
- printf("%d",si[i]+cnm[i][0]);
- for(int j=0;j<si[i];j++) printf(" %d",v[i][j]);
- for(int j=0;j<cnm[i][0];j++) printf(" %d",cnm[i][j+1]);
- printf("\n");
- }
- }
- void Init(){
- memset(si,0,sizeof(si));
- memset(a,0,sizeof(a));
- memset(b,0,sizeof(b));
- }
- int main(){
- int T;
- scanf("%d",&T);
- while(T--){
- scanf("%I64d%I64d",&n,&m);
- ll su=n*(n+1)/2;
- ll av=su/m;
- if(su%m||av<n)printf("NO\n");
- else{
- Init();
- bool ok=fun(n);
- if(ok)out(m);
- else printf("NO\n");
- }
- }
- return 0;
- }
/*
此代码存在局限性数据更新后已不能在AC
待更新……
*/
这个题目看上去的时候第一感觉就是暴力,结果真的一遍就过了
- #include<algorithm>
- #include<iostream>
- #include<cstring>
- #include<cstdio>
- #include<vector>
- #define maxn 100005
- #define ll __int64
- using namespace std;
- int a[maxn];
- vector <int > v[maxn];
- int main(){
- int T;
- scanf("%d",&T);
- while(T--){
- ll n,m;
- scanf("%I64d%I64d",&n,&m);
- ll sum =(n+1)*n/2;
- if(sum%m==0){
- ll ave=sum/m;
- if(ave<n)
- printf("NO\n");
- else{
- memset(v,0,sizeof(v));
- memset(a,0,sizeof(a));
- int t=ave,A=0;
- int flag=0;
- for(int i=n;!flag&&i>=1;i--){
- if(a[i]==0){
- t-=i;
- v[A].push_back(i);
- a[i]=1;
- }
- if(i-1>t){
- for(int j=i-1;t&&j>=1;j--){
- if(t>=j&&a[j]==0){
- v[A].push_back(j);
- t-=j;
- a[j]=1;
- }
- }
- }
- if(t==0){
- t=ave;
- A++;
- }
- }
- if(A==m){
- printf("YES\n");
- for(int i=0;i<m;i++){
- printf("%d",v[i].size());
- for(int j=0;j<v[i].size();j++)
- printf(" %d",v[i][j]);
- printf("\n");
- }
- }
- else
- printf("NO\n");
- }
- }
- else
- printf("NO\n");
- }
- return 0;
- }
HDU 5355 Cake的更多相关文章
- 多校第六场 1003 hdu 5355 Cake(贪心)
题目链接:(数据加强后wa了) hdu 5355 题目大意: 给出一个蛋糕.切成1~n大小的n块.问是否能在不继续分割的情况下拼凑出m等份. 题目分析: 首先我们是可以知道每份蛋糕的尺寸的,利用n*( ...
- 2015多校第6场 HDU 5355 Cake 贪心,暴力DFS
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5355 题意:给你n个尺寸大小分别为1,2,3,…,n的蛋糕,要求你分成m份,要求每份中所有蛋糕的大小之 ...
- HDU 5355 Cake (WA后AC代码,具体解析,构造题)
题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5355 题面: Cake Time Limit: 2000/1000 MS (Java/Others) ...
- HDU 5355 Cake(2015多校第六场,搜索 + 剪枝)
Cake Time Limit: 2000/1000 MS (Java/Others) Memory Limit: 131072/131072 K (Java/Others) Total Sub ...
- HDU 5355 Cake (构造 + 暴力)
题意:给定 n,m,让你把 1 ~ n 分成 m 部分,而且每部分和是一样大的. 析:首先先判断不能分成的,第一种是 sum (1 ~ n 的和)不能被 m 整除,或者 sum / m < n, ...
- 贪心 HDOJ 5355 Cake
好的,数据加强了,wa了 题目传送门 /* 题意:1到n分成m组,每组和相等 贪心:先判断明显不符合的情况,否则肯定有解(可能数据弱?).贪心的思路是按照当前的最大值来取 如果最大值大于所需要的数字, ...
- hdu 5535 Cake 构造+记忆化搜索
链接:http://acm.hdu.edu.cn/showproblem.php?pid=5355 题意:给定n与m,其中1<= n <= 1e5,2 <= m <= 10;问 ...
- hdoj 5355 Cake(分析+二分)
题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5355 分蛋糕的题目,有1-n大小的n个蛋糕,要求平均分成m份,不能切开蛋糕 #include<s ...
- hdu 1722 Cake 数学yy
题链:http://acm.hdu.edu.cn/showproblem.php? pid=1722 Cake Time Limit: 1000/1000 MS (Java/Others) Me ...
随机推荐
- bzoj1231[Usaco2008 Nov]mixup2 混乱的奶牛(状压dp)
1231: [Usaco2008 Nov]mixup2 混乱的奶牛 Time Limit: 10 Sec Memory Limit: 162 MBSubmit: 1032 Solved: 588[ ...
- AOP实现参数的判空问题
不想每次都去判断必传的参数是否为空,写代码太繁琐了,正好最近用了AOP实现权限控制,依葫芦画瓢,现在用它实现参数的判空,至于AOP的原理之类,自己百度了解一下吧 1. NullDisable注解 @D ...
- lua 10进制转换成其它进制table表示
-- params@num integer -- ~) 默认为10 -- NOTE:先不输出符号 function NumberToArray(num, radix) if type(num) ~= ...
- 【JAVA练习】- 给定精度求圆周率π
给定一个精度求圆周率π的近似值 给定公式:π/4=1-1/3+1/5-1/7+1/9-... public static void main(String[] args) { System.out.p ...
- DeltaFish 校园物资共享平台 第一次小组会议
软工小组第一次会议 会议地点:图书馆 会议时间:19:00 ~ 20:00 与会人员:软工小组全体成员 请假人员:无缺席人员:无 记录人:陈志锴 整理人:曾子轩 会议记录 一.确认选题 每一位成员提出 ...
- 浅谈Java三大框架与应用
前言:对于一个程序员来说,尤其是在java web端开发的程序员,三大框架:Struts+Hibernate+Spring是必须要掌握熟透的,因此,下面谈谈java三大框架的基本概念和原理. JAVA ...
- 极客学院免费VIP
[手快福利]用我的链接注册极客学院,你我都能免费得30天VIP!6500+编程开发视频教程随便学,还能下载资料和源码 http://e.jikexueyuan.com/invite/index.htm ...
- 揭开jQuery的面纱
简单地说,jQuery是一个优秀的JavaScript类库,也就是使用JavaScript面向对象的性质编写的一个JavaScript类的集合.jQuery究竟能为我们提供哪些功能呢?简单地说可以从七 ...
- 如何安全使用dispatch_sync
概述 iOS开发者在与线程打交道的方式中,使用最多的应该就是GCD框架了,没有之一.GCD将繁琐的线程抽象为了一个个队列,让开发者极易理解和使用.但其实队列的底层,依然是利用线程实现的,同样会有死锁的 ...
- vue货币格式化组件、局部过滤功能以及全局过滤功能
一.在这里介绍一个vue的时间格式化插件: moment 使用方法: .npm install moment --save. 2 定义时间格式化全局过滤器 在main.js中 导入组件 import ...