题目链接:

http://codeforces.com/problemset/problem/665/D

题意:

给定序列,从中找出最大的子集,使得子集中的数两两相加均为质数。

分析:

貌似有用最大团做的。可是不会,名字太难听也不是很想学。

n只有1000,暴力一发。

如果集合中有1的话,把所有1都放进去,我们最多再找一个偶数。

如果不考虑1的话,两个奇数,两个偶数相加均为偶数,所以最多找一个奇数和一个偶数。

枚举之后判断一下是否为质数就好了。

我觉得整个序列找不到两两相加为质数的时候的说明不是很清楚,wa了之后才知道找不到的话直接输出任何一个数。

代码:

#include<cstdio>
#include<vector>
#include<cstring>
#include<iostream>
using namespace std;
vector<int>v1,v2,v, vv;
const int maxn = 1e3 + 5, maxm = 1e6+ 5;
int a[maxn];
bool isprime[2 * maxm];
void init()
{
memset(isprime, true, sizeof(isprime));
isprime[1] = false;
for(int i = 2; i < 2 * maxm; i++){
if(isprime[i]){
for(int j = 2 * i; j < 2 * maxm; j += i){
isprime[j] = false;
}
}
}
}
int main (void)
{
int n;
scanf("%d", &n);
bool flg = false;
init();
for(int i = 0; i < n; i++){
scanf("%d", &a[i]);
if(a[i] == 1){flg = true;v.push_back(1);}
else if(a[i] & 1) v1.push_back(a[i]);
else v2.push_back(a[i]);
}
if(flg){
for(int i = 0; i < v2.size(); i++){
if(isprime[v2[i] + 1]) {
v.push_back(v2[i]);
break;
}
}
}
bool flag = true;
if(v.size() < 2){
for(int i = 0; i < v1.size(); i++){
for(int j = 0; j < v2.size(); j++){
if(isprime[v1[i] + v2[j]]){ vv.push_back(v1[i]);vv.push_back(v2[j]);flag = false;break;}
}
if(!flag) break;
}
}
if(v.size() == 0){v.push_back(a[0]);}
if(vv.size() < v.size()){
printf("%d\n", v.size());
for(int i = 0; i < v.size(); i++) printf("%d ", v[i]);
}else {
printf("%d\n", vv.size());
for(int i = 0; i < vv.size(); i++) printf("%d ", vv[i]);
}
return 0;
}

Codeforces 665D Simple Subset【构造】的更多相关文章

  1. Codeforces 665D Simple Subset [简单数学]

    题意: 给你n个数,让你从中选一个子集要求子集中的任何两个数相加都是质数. 思路: 一开始把自己坑了,各种想,后来发现一个简单的性质,那就是两个数相加的必要条件是这两个数之中必定一个奇数一个偶数,(除 ...

  2. codeforces 665D Simple Subset

    题目链接 给一个数列, 让你选出其中的m个数, 使得选出的数中任意两个数之和都为质数, m尽可能的大. 首先, 除了1以外的任意两个相同的数相加结果都不是质数. 然后, 不考虑1的话, 选出的数的个数 ...

  3. CodeForces - 665D Simple Subset 想法题

    //题意:给你n个数(可能有重复),问你最多可以取出多少个数使得任意两个数之和为质数.//题解:以为是个C(2,n)复杂度,结果手摸几组,发现从奇偶性考虑,只有两种情况:有1,可以取出所有的1,并可以 ...

  4. CodeFores 665D Simple Subset(贪心)

    D. Simple Subset time limit per test 1 second memory limit per test 256 megabytes input standard inp ...

  5. Educational Codeforces Round 12 D. Simple Subset 最大团

    D. Simple Subset 题目连接: http://www.codeforces.com/contest/665/problem/D Description A tuple of positi ...

  6. coeforces 665D D. Simple Subset(最大团orsb题)

    题目链接: D. Simple Subset time limit per test 1 second memory limit per test 256 megabytes input standa ...

  7. CodeForces 837D - Round Subset | Educational Codeforces Round 26

    /* CodeForces 837D - Round Subset [ DP ] | Educational Codeforces Round 26 题意: 选k个数相乘让末尾0最多 分析: 第i个数 ...

  8. Codeforces 626E Simple Skewness(暴力枚举+二分)

    E. Simple Skewness time limit per test:3 seconds memory limit per test:256 megabytes input:standard ...

  9. Codeforces 837D Round Subset - 动态规划 - 数论

    Let's call the roundness of the number the number of zeros to which it ends. You have an array of n ...

随机推荐

  1. BOM函数之history对象

    前面的话 history对象保存着用户上网的历史记录,从窗口被打开的那一刻算起.由于安全方面的考虑,开发人员无法得到用户浏览器的URL,但借由用户访问过的页面列表,可以在不知道实际URL的情况下实现后 ...

  2. Alert and Action sheets and Timer and Animation

  3. postcss.config.js配置文件的配置方法

    module.exports = { plugins: { 'autoprefixer': {}, } }

  4. bzoj5183 [Baltic2016]Park

    题目描述: bz luogu 题解: 把坐标系看反了持续$WA$系列. 对偶图+并查集维护. 先处理出树对树.树对墙的空隙,然后把人和空隙按从小到大排序. 用并查集维护四面墙之间是否能互相隔断. 代码 ...

  5. [LUOGU] P1880 [NOI1995]石子合并

    题目描述 在一个圆形操场的四周摆放N堆石子,现要将石子有次序地合并成一堆.规定每次只能选相邻的2堆合并成新的一堆,并将新的一堆的石子数,记为该次合并的得分. 试设计出1个算法,计算出将N堆石子合并成1 ...

  6. nginx正则配置解释和fastadmin

    参考:http://www.cnblogs.com/netsa/p/6383094.html 1 2 3 4 5 6 7 8 9 10 11 1.^: 匹配字符串的开始位置:   2. $:匹配字符串 ...

  7. 《零基础入门学习Python》【第一版】视频课后答案第005讲

    测试题答案: 0.Python中: int:整型 bool:布尔类型 float:浮点型 str:字符串类型 1.为什么布尔类型(bool)的TRUE和FALSE分别用0和1表示? 计算机只认识二进制 ...

  8. LeetCode101--对称二叉树

    ''' 给定一个二叉树,检查它是否是镜像对称的. ''' class TreeNode: def __init__(self, x): self.val = x self.left = None se ...

  9. bounds 和frame区别

    仔细看下这个图就知道了

  10. DDL、DML、DCL、DQL的理解

    DDL.DML 和 DCL 的理解 DDL(data definition language)数据库定义语言 的主要语句(操作) Create 语句:可以创建数据库和数据库的一些对象. Drop 语句 ...