题意:

给你n个数vi,你有k次操作。每一次操作你可以从n个数里面挑一个数,然后使得这个数乘于一个正整数。操作完之后,这n个数里面不同数的数量就是权值。你要使得这个值尽可能小。

题解:

如果a%b==0 && a!=b

  b%c==0 && b!=c

那么如果我们进行操作的话,肯定是把c变成a,因为这样消耗的最小操作数最少

我们最后的答案只需要在两种情况中取最小值就可以了

1、我们把n个数都往n个数的公倍数上变

2、如果这n个数里面出现了上面所示的a、b、c的情况,那么我们就把b、c这些数都往a上变

过程:

因为题目求的是操作完之后不同数的数量,那么我们首先记录一下每一个数的出现次数

然后在提前处理一下每一个数的倍数是否在这n个数里面

然后按照每一个数出现的次数排序。为什么?给你一个序列

1 1 2 4

我们如果只有一个操作,那么肯定是把2变成4.这样的话答案就是2

这就意味着,我们要使得1变成4的话,那么只有操作数大于等于3的时候才对最后的结果造成影响

之后就模拟就可以了

AC代码:

  1. /*
  2. 有两种操作,要么是把一种数全部变成他的倍数(尽量大且存在的倍数),要么是将尽量多种类的数变成所有数的公倍数。
  3.  
  4. 那么我们只需要维护出每种数是否存在其倍数,就只能这种数能否进行第一种操作。
  5.  
  6. 只要对每个数因数分解,然后给因数打上标记,就可以知道每个数是否存在其倍数了。复杂度n*sqrt(t),t代表数据范围。
  7. */
  8.  
  9. #include <algorithm>
  10. #include <cmath>
  11. #include <cstdio>
  12. #include <cstdlib>
  13. #include <cstring>
  14. #include <ctime>
  15. #include <iostream>
  16. #include <map>
  17. #include <queue>
  18. #include <set>
  19. #include <vector>
  20. using namespace std;
  21. typedef long long ll;
  22. const int maxn = 1e6 + 5;
  23. const int INF=0x3f3f3f3f;
  24. const int mod = 1000000007;
  25. int v[maxn],num[maxn],vis[maxn],que1[maxn],que2[maxn];
  26. int main()
  27. {
  28. freopen("equal.in","r",stdin);
  29. freopen("equal.out","w",stdout);
  30. int n;
  31. scanf("%d",&n);
  32. for(int i=1;i<=n;++i)
  33. {
  34. scanf("%d",&v[i]);
  35. num[v[i]]++;
  36. }
  37. for(int i=1;i<=n;++i)
  38. {
  39. int tmp=v[i];
  40. if(tmp!=1) vis[1]=1;
  41. int ends=sqrt(tmp);
  42. for(int j=2;j<=ends;++j)
  43. {
  44. if(tmp%j==0)
  45. {
  46. vis[j]=1;
  47. vis[tmp/j]=1;
  48. }
  49. }
  50. }
  51. int pos1=0,pos2=0;
  52. for(int i=1;i<=1000000;++i)
  53. {
  54. if(num[i]==0) continue;
  55. int tmp=i;
  56. if(vis[tmp])
  57. {
  58. que1[pos1++]=num[tmp];
  59. }
  60. que2[pos2++]=num[tmp];
  61. }
  62. sort(que1,que1+pos1);
  63. sort(que2,que2+pos2);
  64. //printf("%d****%d %d\n",pos1,que1[0],que1[1]);
  65. int ans1=0,ans2=0,tmp1=0,tmp2=0;
  66. printf("%d ",pos2);
  67. for(int i=1;i<=n;++i)
  68. {
  69. tmp1+=1;
  70. while(tmp1>=que1[ans1] && ans1<pos1)
  71. {
  72. tmp1-=que1[ans1];
  73. ans1++;
  74. }
  75.  
  76. tmp2+=1;
  77. while(tmp2>=que2[ans2] && ans2<pos2)
  78. {
  79. tmp2-=que2[ans2];
  80. ans2++;
  81. }
  82.  
  83. if(i!=n)
  84. printf("%d ",pos2-max(ans1,ans2-1));
  85. else printf("%d\n",pos2-max(ans1,ans2-1));
  86. }
  87. return 0;
  88. }

Equal Numbers Gym - 101612E 思维的更多相关文章

  1. Sheldon Numbers GYM -- 枚举

    Sheldon Numbers GYM 题意:定义Sheldon Number为其二进制数是ABA……ABA型的或者ABAB……AB的,其中A全为1,B全为0(A>0, B>0),问[m, ...

  2. Codeforces gym101612 E.Equal Numbers(贪心)

    传送:http://codeforces.com/gym/101612 题意:给出一个大小为n的序列a[i],每次选其中一个数乘以一个正整数,问进行k步操作后最少剩下多少种数字,输出0≤k≤n,所有的 ...

  3. Codeforces.GYM101612E.Equal Numbers(贪心)

    题目链接 \(Description\) 给定\(n\)个数,每次可以将任意一个数乘上任意一个正整数. 求\(k\)次操作后,数列中数的种类最少可以是多少.对每个\(0\leq k\leq n\)输出 ...

  4. Random Numbers Gym - 101466K dfs序+线段树

    Tamref love random numbers, but he hates recurrent relations, Tamref thinks that mainstream random g ...

  5. Gym - 101981E 思维

    Gym - 101981EEva and Euro coins 题意:给你两个长度皆为n的01串s和t,能做的操作是把连续k个相同的字符反转过来,问s串能不能变成t串. 一开始把相同的漏看了,便以为是 ...

  6. equal numbers

    给你一个n长度的数组,让你修改0到n次,问每次修改后能剩下不同个数的最小数是多少: 这里有了两种做法,一种是变成他们的lcm这样的话,修改后答案应该是减去改过的个数然后在加一 另一种就是数字修改成序列 ...

  7. Problem D. Berland Railroads Gym - 101967D (思维)

    题目链接:https://cn.vjudge.net/contest/274029#problem/D 题目大意:给你0-9每个数的个数,然后让你找出最大的数,满足的条件是任意三位相连的都能被三整除. ...

  8. Numbers(CodeForces-128D)【思维/list】

    题目链接:https://vjudge.net/problem/CodeForces-128D 题意:给出一组数,要求将这些数排列成一个环,满足每相邻两个数的差值为1,问能否完成. 思路:先取出最小的 ...

  9. Simple Robot Gym - 101102I (思维)

    SaMer is building a simple robot that can move in the four directions: up (^), down (v), left (<) ...

随机推荐

  1. oracle range分区表已经有了MAXVALUE 分区,如何添加分区?要不能删除MAXVALUE分区里的数据,不影响在线应用。

    来做个实验说明该问题:1.创建个分区表SQL> create table p_range_test 2 (id number,name varchar2(100)) 3 partition by ...

  2. DTCC 2020 | 阿里云李飞飞:云原生分布式数据库与数据仓库系统点亮数据上云之路

    简介: 数据库将面临怎样的变革?云原生数据库与数据仓库有哪些独特优势?在日前的 DTCC 2020大会上,阿里巴巴集团副总裁.阿里云数据库产品事业部总裁.ACM杰出科学家李飞飞就<云原生分布式数 ...

  3. Log4j配置按照文件大小和日期分割日志文件

    目录 Log4j 下载地址 文件大小分割日志文件 以日期分割每天产生一个日志文件 自定义信息输出到日志文件 Log4j 下载地址 Log4j是Apache的一个开源项目,通过使用Log4j,我们可以控 ...

  4. 【Oracle】10g查看trace生成文件位置及文件名称

    select  u_dump.value || '/' ||  db_name.value || '_ora_' ||  v$process.spid ||  nvl2(v$process.trace ...

  5. 攻防世界 - Misc(一)

    base64÷4: 1.下载附件,是一个.txt文件,打开是一串字符, 666C61677B453333423746443841334238343143413936393945444442413234 ...

  6. windows下如何安装Python、pandas

    windows下如何安装Python.pandas 本篇主要涵盖以下三部分内容: Python.Pycharm的安装 使用Pycharm创建.运行Python程序 安装pandas 1.Python. ...

  7. 【Not BUG】微软Winform窗体中设计上的Bug,会导致程序编译失败?不,这不是BUG!

    这不是BUG!!! 原文地址: https://www.cnblogs.com/thanks/p/14302011.html 现在让我们回忆一下原文 原文的操作步骤: 1. 新建一个Window Fo ...

  8. 4、python+selenium实现12306模拟登录

    简介: 这里是利用了selenium+图片识别验证,来实现12306的模拟登录,中间也参考了好几个项目,实现了这个小demo,中间也遇到了很多的坑,主要难点在于图片识别和滑动验证这两个方面,图片识别是 ...

  9. [USACO2011 Feb] Cow Line

    原题链接https://www.lydsy.com/JudgeOnline/problem.php?id=3301 康拓展开和逆展开的模板题. #include<iostream> #in ...

  10. Py其他内置函数,文件修改

    其他内置函数 1.abs函数,取绝对值 print(abs(-1)) 2.all函数,判断可迭代对象是否全为真,有假直接假 假:0,'',None print(all([1,2,'1'])) prin ...