题目链接:

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. c语言产生随机数的方法

    在C语言中,rand()函数可以用来产生随机数,但是这不是真真意义上的随机数,是一个伪随机数,是根据一个数,我们可以称它为种子,为基准以某个递推公式推算出来的一系数,当这系列数很大的时候,就符合正态公 ...

  2. jdk concurrent 中 AbstractQueuedSynchronizer uml 图.

    要理解 ReentrantLock 先理解AbstractQueuedSynchronizer 依赖关系. 2

  3. C# 读App.config配置文件[1]:.Net Framework框架

    C# 读App.config配置文件[1]:.Net Framework框架 C# 读App.config配置文件[2]: .Net Core框架 参考:https://www.cnblogs.com ...

  4. 674. Longest Continuous Increasing Subsequence@python

    Given an unsorted array of integers, find the length of longest continuous increasing subsequence (s ...

  5. docker的网络(进阶)

    overlay网络 overlay网络驱动程序会在多个docker守护程序(即多个主机上的docker守护程序)之间创建分布式网络.该网络(overlays)位于特定于主机的网络之上,允许连接到它的容 ...

  6. Python日志(logging)模块,shelve,sys模块

    菜鸟学python第十七天 1.logging 模块 logging模块即日志记录模块 用途:用来记录日志 为什么要记录日志: 为了日后复查,提取有用信息 如何记录文件 直接打开文件,往里写东西 直接 ...

  7. 解决windows管理员已阻止你运行此应用问题

    按WIN+R键,打开“运行”,然后输入“gpedit.msc",就是打开组策略,这个在控制面板中也可以打开. 在组策略里找到“计算机配置”-“Windows设置”-“安全设置”-“本地策略” ...

  8. PAT Basic 1035

    1035 插入与归并 根据维基百科的定义: 插入排序是迭代算法,逐一获得输入数据,逐步产生有序的输出序列.每步迭代中,算法从输入序列中取出一元素,将之插入有序序列中正确的位置.如此迭代直到全部元素有序 ...

  9. Java POI 操作Excel(读取/写入)

    pom.xml依赖: <dependency> <groupId>org.apache.poi</groupId> <artifactId>poi< ...

  10. tabel使用总结

    对日常使用到的tabel做下记录: <table cellspacing="0"><!--单元格间距为零 默认为2 border默认为 0--> <t ...