每次AB秒出 到了C难度陡然上升...翻译都弄不懂...

C 给出一张图 找出两个点的覆盖集(覆盖集是指这图中每条边都有至少一个点在这个点集里面) 并且两个点集没有交集 英文很难看懂...就是二分图的判定 看看这张图是不是二分图 输出两边的点 不是二分图输出-1

坑点是这是special judge 但是题目没说 每个联通块都要进行一次bfs 那些独立点可以不输出也可以随意分配

D 给出k与n个数ci 我们知道一个未知的数x%ci的数 问能不能求出x%k的数

可以利用中国剩余定理来解

如果我们知道 x=A mod c1 = B mod c2 可以求出x的通解  x= lcm(c1,c2)q+z 这里的q是一个倍数

那么当lcm(c1,c2...)是k的倍数的时候 满足 所有的 kq都有lcm()q来对应 所以这时候一定可以通过z求出x%k

所以只需要求一下ci之间的lcm就好啦 最后看lcm是不是k的倍数

但是 直接求lcm会超int什么的

可以每次都让lcm%=k 一旦lcm为k的倍数的时候就永远为0下去了

E A有n个硬币 B有k价值的东西 A从这些硬币中找出一些使和等于k和B交换 A想知道B能利用这些硬币摆出多少的状态 都输出

设置dp[i][j] i表示A拿出的硬币的总和 j表示从这些硬币中拿出来的部分的总和 1 为存在 0 为不存在

初始dp[0][0]=1

关于代码内dp方程的转移:首先枚举硬币的种类 再枚举i 需要注意的是i要从大往小去枚举 这和背包中01和完全的区别类似 当我们从上向下枚举的时候 就不会出现同一种东西加成在小东西上 又在小东西升级的大东西上再次作用这种状况了 问题中硬币是只有一个的 所以是01 从上向下枚举 而当面对完全背包的情况下 我们可以无限制的加入东西 所以应该从小往下枚举 枚举j的时候只需要从0向k枚举就好 因为之后还会进行判断 dp[i][j]==1 这时候就说明这种状态是存在的 然后我们对dp[i+c][j]和dp[i+c][j+c]进行操作 可以看出 由于枚举硬币的顺序 每个状态的i和j都只能被放进去一种硬币

初始化的时候只做dp[0][0]就好 其余的让它自己去推...

C

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<map>
#include<math.h>
#include<iostream>
#include<queue>
using namespace std;
int n,m;
int point[100050];
struct node
{
int v;
int nex;
};
node b[200050];
int cnt;
void add(int u,int v)
{
b[cnt].v=v;
b[cnt].nex=point[u];
point[u]=cnt;
cnt++;
}
int co[100050];
bool bfs(int z)
{
queue<int >q;
q.push(z);
co[z]=1;
while(!q.empty())
{
int f=q.front();
q.pop();
for(int tt=point[f]; tt!=-1; tt=b[tt].nex)
{
int v=b[tt].v;
if(co[v]==0)
{
if(co[f]==1)
{
co[v]=2;
q.push(v);
}
else
{
co[v]=1;
q.push(v);
}
}
else if(co[v]==co[f])
{
return false;
}
else
{
continue;
}
}
}
return true;
} int main()
{
cin>>n>>m;
cnt=0;
for(int i=1; i<=n; i++)
{
point[i]=-1;
co[i]=0;
}
for(int i=1; i<=m; i++)
{
int u,v;
cin>>u>>v;
add(u,v);
add(v,u);
}
bool ans=true;
for(int i=1;i<=n;i++){
if(co[i]==0){
ans=bfs(i);
if(ans==false){
printf("-1\n");
break;
}
}
}
if(ans==true){
int res=0;
for(int i=1; i<=n; i++)
{
if(co[i]==1)
{
res++;
}
}
printf("%d\n",res);
int c=0;
for(int i=1; i<=n; i++)
{
if(co[i]==1)
{
printf("%d",i);
c++;
if(c==res)
printf("\n");
else printf(" ");
}
}
c=0;
res=0;
for(int i=1; i<=n; i++)
{
if(co[i]!=1)
{
res++;
}
}
printf("%d\n",res);
for(int i=1; i<=n; i++)
{
if(co[i]!=1)
{
printf("%d",i);
c++;
if(c==res)
printf("\n");
else printf(" ");
}
}
}
}

D

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<map>
#include<iostream>
using namespace std;
long long k;
int n;
long long gcd(long long a,long long b)
{
if(b==0)
return a;
return gcd(b,a%b);
}
long long lcm(long long a, long long b)
{
return a*b/gcd(a,b);
}
int main()
{
scanf("%d%lld",&n,&k);
long long cc;
scanf("%lld",&cc);
long long gbs=cc;
bool ans=false;
if(k==1)
{
ans=true;
}
if(n==1)
{
if(cc%k==0)
ans=true;
}
for(int i=2; i<=n; i++)
{
scanf("%lld",&cc);
if(ans==true)
continue;
gbs=lcm(cc,gbs);
gbs%=k;
if(gbs==0)
{
ans=true;
}
}
if(ans==true)
{
printf("Yes\n");
}
else printf("No\n");
}

E

#include<stdio.h>
#include<string.h>
#include<algorithm>
#include<math.h>
#include<map>
using namespace std;
int n,k;
int c[505];
int dp[500][500];
int main()
{
scanf("%d%d",&n,&k);
for(int i=1; i<=n; i++)
scanf("%d",&c[i]);
memset(dp,0,sizeof(dp));
/*for(int i=1; i<=n; i++)
{
dp[c[i]][c[i]]=dp[c[i]][0]=1;
}*/
dp[0][0]=1;
for(int i=1; i<=n; i++)
{
for(int j=k-c[i]; j>=0; j--)
{
for(int o=0; o<=k; o++)
{
if(dp[j][o]==1)
{
dp[j+c[i]][o]=1;
if(o+c[i]<=k)
{
dp[j+c[i]][o+c[i]]=1;
}
}
}
}
}
int ans=0;
for(int i=0; i<=k; i++)
{
if(dp[k][i]==1)
{
ans++;
}
}
printf("%d\n",ans);
int s=0;
for(int i=0; i<=k; i++)
{
if(dp[k][i]==1)
{
{
printf("%d",i);
s++;
if(s==ans)
printf("\n");
else printf(" ");
}
}
}
}

拖了两天才补完的cf..补题的感觉真是亦可赛艇...

Codeforces Round #360 (Div. 2) C D E的更多相关文章

  1. Codeforces Round #360 (Div. 1) D. Dividing Kingdom II 暴力并查集

    D. Dividing Kingdom II 题目连接: http://www.codeforces.com/contest/687/problem/D Description Long time a ...

  2. Codeforces Round #360 (Div. 2) D. Remainders Game 数学

    D. Remainders Game 题目连接: http://www.codeforces.com/contest/688/problem/D Description Today Pari and ...

  3. Codeforces Round #360 (Div. 2) C. NP-Hard Problem 水题

    C. NP-Hard Problem 题目连接: http://www.codeforces.com/contest/688/problem/C Description Recently, Pari ...

  4. Codeforces Round #360 (Div. 2) B. Lovely Palindromes 水题

    B. Lovely Palindromes 题目连接: http://www.codeforces.com/contest/688/problem/B Description Pari has a f ...

  5. Codeforces Round #360 (Div. 2) A. Opponents 水题

    A. Opponents 题目连接: http://www.codeforces.com/contest/688/problem/A Description Arya has n opponents ...

  6. Codeforces Round #360 (Div. 1)A (二分图&dfs染色)

    题目链接:http://codeforces.com/problemset/problem/687/A 题意:给出一个n个点m条边的图,分别将每条边连接的两个点放到两个集合中,输出两个集合中的点,若不 ...

  7. Codeforces Round #360 (Div. 1) D. Dividing Kingdom II 并查集求奇偶元环

    D. Dividing Kingdom II   Long time ago, there was a great kingdom and it was being ruled by The Grea ...

  8. Codeforces Round #360 (Div. 2) E. The Values You Can Make DP

    E. The Values You Can Make     Pari wants to buy an expensive chocolate from Arya. She has n coins, ...

  9. Codeforces Round #360 (Div. 2) E. The Values You Can Make 01背包

    题目链接: 题目 E. The Values You Can Make time limit per test:2 seconds memory limit per test:256 megabyte ...

随机推荐

  1. WebSocket技术

    webSocket技术 在html5技术革新中,加入了WebSocket技术 1.webSocket实际是TCP连接 webSocket在最初将发送http连接请求到服务器端, 但是在header中加 ...

  2. July 17th, Week 30th Sunday, 2016

    You are beautiful, but that is not why I love you. 你如此美丽,但我并非因此而爱你. Although we have always been tol ...

  3. linux下文件压缩与解压操作

    对于刚刚接触Linux的人来说,一定会给Linux下一大堆各式各样的文件名给搞晕.别个不说,单单就压缩文件为例,我们知道在Windows下最常见的压缩文件就只有两种,一是,zip,另一个是.rap.可 ...

  4. yum_rpm(利用dvd建立本地yum库)

    #wget "http://mirrorlist.centos.org/?release=6&arch=x86_64&repo=os" 建立起了index.html ...

  5. iOS通过ASIHTTPRequest提交JSON数据

    先验知识——什么是ASIHTTPRequest? 使用iOS SDK中的HTTP网络请求API,相当的复杂,调用很繁琐,ASIHTTPRequest就是一个对CFNetwork API进行了封装,并且 ...

  6. 图解VS2010打包全过程(转)

    最近刚刚打包发布了用VS2010开发的一个收费系统,借此讲一讲打包过程,供大家参考. 首先打开已经完成的工程,如图: 下面开始制作安装程序包. 第一步:[文件]——[新建]——[项目]——安装项目. ...

  7. 把一个SVN项目的目录结构 导入到另外一个空白的SVN项目里

    1 选好源目录,选中“check out” 2 选中想要的目录结构 3 选择具体的目录 4 确定,最后开始更新,成功!

  8. jmeter之调度器配置

    Jmeter的线程组设置里有一个调配器设置,用于设置该线程组下脚本执行的开始时间.结束时间.持续时间及启动延迟时间.当需要半夜执行性能测试时会用到这个功能. ps:设置调度器配置,需要将前面的循环次数 ...

  9. http://blog.csdn.net/jiazimo/article/details/17265061

    http://blog.csdn.net/jiazimo/article/details/17265061

  10. BZOJ3796 : Mushroom追妹纸

    将S1与S2用#号拼接在一起形成S串 将S3与S串跑KMP求出S3在S串中每次出现的位置l[i] 对于S串每个后缀i,求出f[i]表示该串不包含S3串的最长前缀 然后求出S串的后缀数组 先从小到大扫描 ...