题意简述

给出正整数n,你要把1-n之间的正整数分成尽可能多组,使得每一组两个数的最大公约数大于1;输出能分成最多组的个数,并按任意顺序输出每组的两个数.

很妙的一道题。

首先我们考虑去处理每个质数的倍数,那么这个质数一定是小于等于 n/2 的,不然它在 n 的范围内是不会有倍数的。

那么我们先把 $1~n/2$ 范围内的所有质数筛出来。

枚举质数

然后我们要怎么用质数去处理答案呢?

首先我们从大到小枚举这些质数,然后去枚举它的倍数。

然鹅这样复杂度不会炸么?不会。 $O(\sigma_{i=2}^{n/2}n/i)$ 的复杂度吧,而且还远达不到。

信仰一下应该是过得了的,实际上确实也过了。

处理倍数

然后我们再考虑如果这些倍数该怎么处理。

我们首先看这些倍数有没有被使用过,没有的话就入栈。

最优性理解

那么为什么能用就入栈的解法最优呢?

其实很简单,因为当前枚举那个数可以被当前的质数整除,那么该数与当前枚举质数的倍数去匹配肯定不会产生更劣的结果。

那么如果有数字剩下来呢?

如果说当前枚举质数的未使用过的倍数有奇数个,那么我们可以将第 2 个倍数与最后一个换一下,然后弹出栈,标记为未使用。

为什么这样做能达到最优?

考虑第二个倍数一定是 2 的倍数,那么把他弹出的话就可以和 2 的倍数去匹配,而且我们每次遇到奇数个的情况都是弹 2 的倍数,那么这些多余的数就可以凑一块儿了。

 1 //by Judge
2 #include<vector>
3 #include<cstdio>
4 #include<iostream>
5 #define P make_pair
6 using namespace std;
7 const int M=1e5+11;
8 char sr[1<<21],z[20];int C=-1,Z;
9 inline void Ot(){fwrite(sr,1,C+1,stdout),C=-1;}
10 inline void print(int x,char chr='\n'){
11 if(C>1<<20)Ot();if(x<0)sr[++C]=45,x=-x;
12 while(z[++Z]=x%10+48,x/=10);
13 while(sr[++C]=z[Z],--Z);sr[++C]=chr;
14 } int n,cnt,ans,top,prim[M],is[M],vis[M],num[M];
15 pair<int,int> tmp[M];
16 inline void prep(){
17 for(int i=2;i<=n>>1;++i){
18 if(!is[i]) prim[++cnt]=i;
19 for(int j=1;j<=cnt&&i*prim[j]<=n/2;++j){
20 is[i*prim[j]]|=1;
21 if(i%prim[j]==0) break;
22 }
23 }
24 }
25 int main(){
26 scanf("%d",&n),prep();
27 for(int i=cnt;i;--i){ top=0;
28 for(int j=prim[i];j<=n;j+=prim[i])
29 if(!vis[j]) num[++top]=j,vis[j]|=1;
30 if(top&1) swap(num[2],num[top]),vis[num[top]]=0,--top;
31 for(int j=1;j<=top;j+=2) tmp[++ans]=P(num[j],num[j+1]);
32 } print(ans);
33 for(int i=1;i<=ans;++i)
34 print(tmp[i].first,' '),
35 print(tmp[i].second);
36 return Ot(),0;
37 }

CF449C:Jzzhu and Apples的更多相关文章

  1. CF449C:Jzzhu and Apples——题解

    https://vjudge.net/problem/CodeForces-449C 题目大意:1-n编号的苹果两两一对,他们的最大公约数不为1,求这些对的最大匹配. ———————————————— ...

  2. Codeforces Round #257 (Div. 2) E题:Jzzhu and Apples 模拟

    E. Jzzhu and Apples time limit per test 1 second memory limit per test 256 megabytes input standard ...

  3. Codeforces 450E:Jzzhu and Apples(构造,数学)

    E. Jzzhu and Apples time limit per test: 1 seconds memory limit per test: 256 megabytes input: stand ...

  4. CF449C Jzzhu and Apples (筛素数 数论?

    Codeforces Round #257 (Div. 1) C Codeforces Round #257 (Div. 1) E CF450E C. Jzzhu and Apples time li ...

  5. Codeforces 449.C Jzzhu and Apples

    C. Jzzhu and Apples time limit per test 1 second memory limit per test 256 megabytes input standard ...

  6. CF449 C. Jzzhu and Apples

    /* http://codeforces.com/problemset/problem/449/C cf 449 C. Jzzhu and Apples 数论+素数+贪心 */ #include &l ...

  7. Codeforces 449C Jzzhu and Apples 贪心 (看题解)

    Jzzhu and Apples 从大的质因子开始贪心, 如果有偶数个则直接组合, 如果是奇数个留下那个质数的两倍, 其余两两组合. #include<bits/stdc++.h> #de ...

  8. CF 450E Jzzhu and Apples 数学+模拟

    E. Jzzhu and Apples time limit per test 1 second memory limit per test 256 megabytes input standard ...

  9. CF449C Jzzhu and Apples

    嘟嘟嘟 这道题正解是怎么对的其实我也不清楚,总之靠感性理解吧. 首先当然要把1到n / 2的素数都筛出来,因为两两能配对的数一定都是这些素数的倍数.这也就说明对于(n / 2, n]的素数,他们一定不 ...

随机推荐

  1. TIMESTAMP使用遇到得麻烦

    mysql按日期查询报空,怎么查看日志发现是14:36:01.709(Timestamp), 参数出了问题 2018-04-17 14:36:16,887 [http-nio-8080-exec-5] ...

  2. windows环境配置计划任务让weblogic的servers开机启动【原】

    准备脚本 注意如果weblogic在D盘,那么以下cmd中的所有C:都要替换成D: , 因为windows需要切盘符. 启动weblogic管理服务adminServer 的文件: startAdmi ...

  3. 2018牛客网暑期ACM多校训练营(第三场)C Shuffle Cards(可持久化平衡树/splay)

    题意 牌面初始是1到n,进行m次洗牌,每次抽取一段放到最前面.求最后的序列. 分析 神操作!!!比赛时很绝望,splay技能尚未点亮,不知道怎么用. 殊不知,C++库里有rope神器,即块状链表. 基 ...

  4. MySQL忘记root密码的解决办法

    # 1.停掉MySQL进程 [root@standby ~]# /etc/init.d/mysqld stop Shutting down MySQL... SUCCESS! [root@standb ...

  5. Java入门系列Java NIO

    jdk1.4中新加入的NIO,引入了通道与缓冲区的IO方式,它可以调用Native方法直接分配堆外内存,这个堆外内存就是本机内存,不会影响到堆内存的大小.

  6. ImageView获取宽高

    在Android里放置一个ImageView im1,宽和高都是200.以下代码都是直接在OnCreate里使用. 1.在Android OnCreate里如果直接使用iv.GetWidth()返回值 ...

  7. MyEclipse2017 隐藏回车换行符

    Preferences->Text Editor->Show Whitespace characters(configure visibility)->Transparency Le ...

  8. 【四】Java虚拟机内存区域初识

     一.线程独占区  1.程序计数器 程序计数器是一块处于线程独占区较小的内存空间,它可以看是当前线程所执行的字节码的行号指示器. 如果线程执行的是Java方法,这个计数器记录的是正在执行的虚拟机字节码 ...

  9. Mysql宽字节注入(转)

    尽管现在呼吁所有的程序都使用unicode编码,所有的网站都使用utf-8编码,来一个统一的国际规范.但仍然有很多,包括国内及国外(特别是非英语国家)的一些cms,仍然使用着自己国家的一套编码,比如g ...

  10. 【bzoj 3173】[Tjoi2013]最长上升子序列

    Description 给定一个序列,初始为空.现在我们将1到N的数字插入到序列中,每次将一个数字插入到一个特定的位置.每插入一个数字,我们都想知道此时最长上升子序列长度是多少? Input 第一行一 ...