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的更多相关文章

  1. 多校第六场 1003 hdu 5355 Cake(贪心)

    题目链接:(数据加强后wa了) hdu 5355 题目大意: 给出一个蛋糕.切成1~n大小的n块.问是否能在不继续分割的情况下拼凑出m等份. 题目分析: 首先我们是可以知道每份蛋糕的尺寸的,利用n*( ...

  2. 2015多校第6场 HDU 5355 Cake 贪心,暴力DFS

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5355 题意:给你n个尺寸大小分别为1,2,3,…,n的蛋糕,要求你分成m份,要求每份中所有蛋糕的大小之 ...

  3. HDU 5355 Cake (WA后AC代码,具体解析,构造题)

    题目链接:http://acm.hdu.edu.cn/showproblem.php? pid=5355 题面: Cake Time Limit: 2000/1000 MS (Java/Others) ...

  4. HDU 5355 Cake(2015多校第六场,搜索 + 剪枝)

    Cake Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 131072/131072 K (Java/Others) Total Sub ...

  5. HDU 5355 Cake (构造 + 暴力)

    题意:给定 n,m,让你把 1 ~ n 分成 m 部分,而且每部分和是一样大的. 析:首先先判断不能分成的,第一种是 sum (1 ~ n 的和)不能被 m 整除,或者 sum / m < n, ...

  6. 贪心 HDOJ 5355 Cake

    好的,数据加强了,wa了 题目传送门 /* 题意:1到n分成m组,每组和相等 贪心:先判断明显不符合的情况,否则肯定有解(可能数据弱?).贪心的思路是按照当前的最大值来取 如果最大值大于所需要的数字, ...

  7. hdu 5535 Cake 构造+记忆化搜索

    链接:http://acm.hdu.edu.cn/showproblem.php?pid=5355 题意:给定n与m,其中1<= n <= 1e5,2 <= m <= 10;问 ...

  8. hdoj 5355 Cake(分析+二分)

    题目链接:http://acm.hdu.edu.cn/showproblem.php?pid=5355 分蛋糕的题目,有1-n大小的n个蛋糕,要求平均分成m份,不能切开蛋糕 #include<s ...

  9. hdu 1722 Cake 数学yy

    题链:http://acm.hdu.edu.cn/showproblem.php? pid=1722 Cake Time Limit: 1000/1000 MS (Java/Others)    Me ...

随机推荐

  1. nodejs安装express

    最近在看<Node.js开发指南>,看到使用nodejs进行web开发的时候,准备创建ejs项目遇到问题了, 书上命令为: 1 express -t ejs microblog 可是执行后 ...

  2. Eclipse项目包上出现红叉如何去除

    Eclipse项目包上出现红叉是因为jdk的版本不一致. 项目名--->Properties----->Java Compiler 图1:

  3. BZOJ 1975 k短路 A*

    思路: 直接上A* //By SiriusRen #include <queue> #include <cstdio> #include <cstring> #in ...

  4. SQLServer2008 使用BCP导入导出表数据

    --先开启cmdshell EXEC sp_configure 'show advanced options', 1 GO RECONFIGURE GO EXEC sp_configure 'xp_c ...

  5. 关于MYSQL 存储过程的文章摘录

    1.      存储过程简介   我们常用的操作数据库语言SQL语句在执行的时候需要要先编译,然后执行,而存储过程(Stored Procedure)是一组为了完成特定功能的SQL语句集,经编译后存储 ...

  6. Deutsch lernen (02)

    1. fließend a. 流利的 Meine französische Freundin spricht fließend Deutsch.     流动的 Der Verkehr wickelt ...

  7. 安装rails卡住很慢 出现302 Moved Temporarily

    在MAC上安装rails的时候,使用命令$ gem install rails 发现一直没响应,使用$ gem install rails-V命令发现,安装会在中间卡住,出现302 Moved Tem ...

  8. OpenCV:Adaboost训练时数据扩增

    更准确的模型需要更多的数据,对于传统非神经网络机器学习方法,不同的特征需要有各自相符合的数据扩增方法. 1.   在使用opencv_traincascade.exe 过程中,图像读取在 classi ...

  9. SQL 分组

  10. HTML 5语义化标签

    HTML 5的革新之一:语义化标签一节元素标签. 在HTML 5出来之前,我们用div来表示页面章节,但是这些div都没有实际意义.(即使我们用css样式的id和class形容这块内容的意义).这些标 ...