CodeForces 757B Bash's Big Day(线性筛)

题意:给你一个集合,让你找到一个最大的子集,使得子集里面的元素的gcd!=1,输出子集的元素的个数。

思路:先将集合里面的元素哈希,再线性筛。

PS:明明以前做过类似的题的,结果又忘了,卡了好久最后打表过的。

 1 #include <iostream>
 2 #include <queue>
 3 #include <stack>
 4 #include <cstdio>
 5 #include <vector>
 6 #include <map>
 7 #include <set>
 8 #include <bitset>
 9 #include <algorithm>
10 #include <cmath>
11 #include <cstring>
12 #include <cstdlib>
13 #include <string>
14 #include <sstream>
15 #include <time.h>
16 #define x first
17 #define y second
18 #define pb push_back
19 #define mp make_pair
20 #define lson l,m,rt*2
21 #define rson m+1,r,rt*2+1
22 #define mt(A,B) memset(A,B,sizeof(A))
23 #define mod 1000000007
24 using namespace std;
25 typedef long long LL;
26 const double PI = acos(-1);
27 const int N=1e5+10;
28 const int inf = 0x3f3f3f3f;
29 const LL INF=0x3f3f3f3f3f3f3f3fLL;
30 int vis[N],vik[N],ans=-inf;
31 void solve(int n)
32 {
33     int p=0;
34     mt(vis,0);
35     for(int i=2;i<=n;i++)
36     {
37         if(!vis[i])
38         {
39             p=0;
40             for(int j=i;j<=n;j+=i)
41             {
42                 vis[j]=1;
43                 p+=vik[j];
44             }
45             ans=max(ans,p);
46         }
47     }
48 }
49 int main()
50 {
51 #ifdef Local
52     freopen("data.txt","r",stdin);
53 #endif
54     int n,x,maxn=-inf;
55     cin>>n;
56     for(int i=0;i<n;i++)
57     {
58         cin>>x;
59         vik[x]++;
60         maxn=max(maxn,x);
61     }
62     solve(maxn);
63     if(ans==-inf)ans=1;
64     cout<<ans<<endl;
65 #ifdef Local
66     cerr << "time: " << (LL) clock() * 1000 / CLOCKS_PER_SEC << " ms" << endl;
67 #endif
68 }
View Code

再附上打表的暴力代码

 1 #include <iostream>
 2 #include <queue>
 3 #include <stack>
 4 #include <cstdio>
 5 #include <vector>
 6 #include <map>
 7 #include <set>
 8 #include <bitset>
 9 #include <algorithm>
10 #include <cmath>
11 #include <cstring>
12 #include <cstdlib>
13 #include <string>
14 #include <sstream>
15 #include <time.h>
16 #define x first
17 #define y second
18 #define pb push_back
19 #define mp make_pair
20 #define lson l,m,rt*2
21 #define rson m+1,r,rt*2+1
22 #define mt(A,B) memset(A,B,sizeof(A))
23 #define mod 1000000007
24 using namespace std;
25 typedef long long LL;
26 const double PI = acos(-1);
27 const int N=2e5+10;
28 const int inf = 0x3f3f3f3f;
29 const LL INF=0x3f3f3f3f3f3f3f3fLL;
30 LL a[N],vis[N],via[N];
31 vector<LL> Q;
32 vector<LL> P[N];
33 void init()
34 {
35     mt(vis,0);
36     for(LL i=2;i<=100000;i++)
37     {
38         if(!vis[i])
39         {
40             Q.push_back(i);
41             for(LL j=i*i;j<=100000;j+=i)
42             {
43                 vis[j]=1;
44             }
45         }
46     }
47 }
48 void solve(LL n)
49 {
50      LL o=n;
51      for(int i=0;i<Q.size()&&n!=1;i++)
52      {
53          if(n%Q[i]==0)
54          {
55              P[o].pb(Q[i]);
56              while(n%Q[i]==0)
57              {
58                  n/=Q[i];
59              }
60          }
61      }
62 }
63 int main()
64 {
65 #ifdef Local
66     freopen("data.txt","r",stdin);
67 #endif
68     int n;
69     LL sum=-INF;
70     init();
71     cin>>n;
72     mt(via,0);
73     for(int i=0;i<n;i++)scanf("%I64d",&a[i]);
74     for(LL i=1;i<=100000;i++)
75     {
76         solve(i);
77     }
78     for(int i=0;i<n;i++)
79     {
80         for(int j=0;j<P[a[i]].size();j++)
81         {
82             via[P[a[i]][j]]++;
83         }
84     }
85     for(int i=0;i<Q.size();i++)
86     {
87         sum=max(sum,via[Q[i]]);
88     }
89     if(sum==0)sum=1;
90     cout<<sum<<endl;
91     //for(int i=0;i<10;i++)cout<<Q[i]<<" ";*/
92 
93 #ifdef Local
94     cerr << "time: " << (LL) clock() * 1000 / CLOCKS_PER_SEC << " ms" << endl;
95 #endif
96 }
View Code

 

转载于:https://www.cnblogs.com/27sx/p/6283704.html

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/356277.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

macbook pro python开发_Mac打造python2 python3开发环境

最新版的MacOS Sierra默认带的python环境仍然为2.7.10&#xff0c;本文将介绍使用Brew安装python3.5并做简单的配置&#xff0c;打造python2&#xff0c;python3共存的开发环境直接尝试brew安装&#xff0c;提示需要执行brew link gdbmthatsitdeMacBook-Pro:~ thatsit$ brew in…

存进销系统 c语言大作业,c语言,程序设计大题,*纳税以系统(2)求法,求解...

话题&#xff1a;要求将2元兑换成有伍角贰角和壹角(每种都有),问有...问&#xff1a;要求将2元兑换成有伍角贰角和壹角(每种都有),问有几种兑换法?(c语言程...推荐回答&#xff1a;#include int main(void) { int i_5,i_2,i_1; for(i_50;i_5话题&#xff1a;题目:销售管理系统…

将2个字符写入单个Java char

这是创建超低延迟的Chronicle FIX-Engine时使用的另一个好技巧。 在从字节流中读取数据时&#xff0c;如果可能的话&#xff0c;将数据存储在char而不是将其读取到String效率更高。 &#xff08;至少您要避免创建String对象&#xff0c;尽管可以通过使用缓存或使用CharSequenc…

时间管理的6句话

早起 避免开会 避免多任务&#xff0c;保持单进程集中注意力、高效工作&#xff0c;每天最多4小时 你没空时不会做的事情&#xff0c;有空了也不会做 划分任务的优先级&#xff0c;不要把急切当作重要 转载于:https://www.cnblogs.com/easonw/p/6286977.html

h5页面保存img_一文彻底解决HTML5页面中长按保存图片功能

本文详细介绍了如何在H5中实现长按保存图片的功能。长按保存图片是现在一些宣传页H5中很常见的需求&#xff0c;但是js没有这样的能力&#xff0c;所以要么借助android或ios的原生能力,要么用canvas自己画一个(截屏)&#xff0c;相比较原生成本太高&#xff0c;且必须依赖于app…

c语言float m1 m2什么意思,m1和m2的区别,一文带你秒懂这两者的关联

摩路由M1作为Moto旗下首款路由器&#xff0c;自去年发布以来&#xff0c;备受瞩目。几个月下来&#xff0c;借着强大的信号覆盖和穿墙能力&#xff0c;赢得了不少用户的认可&#xff0c;甚至推崇。不久前发布的摩路由M2&#xff0c;在M1的基础上进行了升级&#xff0c;功能和配…

在fedora下面安装ftp服务器

Fedora版本&#xff1a;Fedora 12 1. 安装vsftp [java] view plaincopy #yum install vsftpd 一路yes&#xff0c;最后提示安装成功。 2. 配置vsftpd.conf。 [java] view plaincopy #vi /etc/vsftpd/vsftpd.conf 将vsftpd.conf文件中的主要设置如下&#xff1a; [java] view …

jenkin swindows启动_windows启动过程

展开全部认真看完这个也许你会有收获的&#xff1a;Windows启动e68a84e8a2ad62616964757a686964616f31333231626165过程介绍相信不少人碰到过装了个什么东西之后&#xff0c;重启Windows就发现起不来了。所以&#xff0c;想把Windows启动过程中作了些什么事情&#xff0c;分哪些…

c语言让电脑发出滴滴声代码,centos命令行控制电脑发出滴滴声——使用beep把警告变为music...

需要先安装beep命令&#xff0c;在ubuntu中可使用apt-get install beep进行安装&#xff0c;在centos中需要先安装repoforge源&#xff0c;然后才使用yum install -y beep进行安装。repoforge源安装后便可进行beep的安装&#xff1a;[rootlocalhost ~]# modprobe pcspkr[rootlo…

如何让代码更易于维护_易于使用的单位和集成代码

如何让代码更易于维护此示例说明如何使用Maven和Sonar为单元和集成测试生成覆盖率。 它使用非常简单的技术&#xff0c;只需10-15分钟即可在任何现有的Maven构建中运行。 它可以用于单元&#xff0c;集成&#xff0c;ATDD或任何其他类型的测试套件。 覆盖率结果显示在声纳中。 …

cascade sqlite 数据库_ON DELETE CASCADE无法正常工作在ios中的sqlite3中

通过启用pragma foreignkeys ON,我以编程方式在ios中创建了一个.sqlite文件NSFileManager *theFileManager [NSFileManager defaultManager];if ([theFileManager fileExistsAtPath:[self getDatabasePath]] NO){char *theError;const char *databasePath [[self getDatabas…

调试 ASP 程序脚本

调试 ASP 脚本 无论您的计划多么精密、经验多么丰富&#xff0c;脚本错误 (bug) 可能在最初就使您的 ASP 服务器端的脚本无法正确运行。也就是说调试&#xff0c;即查找和纠正脚本错误&#xff0c;对开发一个成功的和强健的 ASP 程序是非常重要的。 Microsoft 脚本调试工具 Mic…

C语言用循环写出新年祝福语图案,非常漂亮的新年祝福!C语言实现漂亮的烟花效果...

本文实例为大家分享了C语言实现漂亮的烟花效果展示的具体代码&#xff0c;供大家参考&#xff0c;具体内容如下程序名称&#xff1a;祝福烟花&#xff0c;祝福朋友编译环境&#xff1a;VC6.0 && easyx(立冬版)#include #include #include #include #include #include #…

用Java和Python模仿Kotlin构建器

介绍 Kotlin可能现在是我最喜欢的语言&#xff0c;并且它可能提供的最酷的功能之一是基于几个功能构建的类型安全的生成器&#xff08;稍后解释&#xff09;。 我发现自己真的很想在其他两种主要语言&#xff08;Java和Python&#xff09;中使用此功能。 本文解释了我认为与使用…

python刷阅读_通过python+selenium3实现浏览器刷简书文章阅读量

准备工作下载python&#xff0c;本文以python3.6为例。python3.6下载地址&#xff1a;python3下载地址&#xff0c;选择合适的版本安装。安装成功后&#xff0c;打开命令提示符&#xff0c;在其中输入python&#xff0c;显示如下信息&#xff0c;则说明安装成功。C:\Users\Ubun…

【原】移动web资源整理

2013年初接触移动端&#xff0c;简单做下总结&#xff0c;首先了解下移动web带来的问题 设备更新换代快——低端机遗留下问题、高端机带来新挑战浏览器厂商不统一——兼容问题多网络更复杂——弱网络&#xff0c;页面打开慢低端机性能差——页面操作卡顿HTML5新技术多——学习成…

android的md动画,Android-notes/动画体系详解.md at master · drs0214/Android-notes · GitHub

Android 动画详解&#xff1a;属性动画、View 动画和帧动画在 Android 中&#xff0c;基本的动画共有三种类型&#xff1a;View 动画&#xff1a;也叫视图动画或者补间动画&#xff0c;主要是指 android.view.animation 包下面的一些类&#xff0c;只能被用来设置给 View&#…

蓝桥杯省赛考点_【蓝桥杯单片机01】从历年决赛真题中寻找单片机常见的考点...

【蓝桥杯单片机01】从历年决赛真题中寻找单片机常见的考点广东职业技术学院 欧浩源【第三届&#xff1a;门禁系统】1、功能简述“门禁系统”主要有两种工作模式&#xff1a;模式1&#xff1a;7&#xff1a;00&#xff5e;22&#xff1a;00为自动门状态&#xff0c;该状态下门的…

android 5.0 新功能,Android 5.0新特性有哪些?安卓5.0新功能汇总

Android 5.0新特性有哪些&#xff1f;经过一段时间曝光与测试后&#xff0c;期待已久的Android L系统正式发布了&#xff0c;新一代安卓系统正式名称为Android 5.0 Lollipop(棒棒糖)。Android 5.0新特性有哪些呢&#xff1f;下面&#xff0c;由百事网小编盘大家盘点一下安卓5.0…

cks子,间谍,局部Mo子和短管

本文是我们名为“ 用Mockito进行测试 ”的学院课程的一部分。 在本课程中&#xff0c;您将深入了解Mockito的魔力。 您将了解有关“模拟”&#xff0c;“间谍”和“部分模拟”的信息&#xff0c;以及它们相应的Stubbing行为。 您还将看到使用测试双打和对象匹配器进行验证的过…