Equal Numbers Gym - 101612E 思维
题意:
给你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代码:
/*
有两种操作,要么是把一种数全部变成他的倍数(尽量大且存在的倍数),要么是将尽量多种类的数变成所有数的公倍数。 那么我们只需要维护出每种数是否存在其倍数,就只能这种数能否进行第一种操作。 只要对每个数因数分解,然后给因数打上标记,就可以知道每个数是否存在其倍数了。复杂度n*sqrt(t),t代表数据范围。
*/ #include <algorithm>
#include <cmath>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <ctime>
#include <iostream>
#include <map>
#include <queue>
#include <set>
#include <vector>
using namespace std;
typedef long long ll;
const int maxn = 1e6 + 5;
const int INF=0x3f3f3f3f;
const int mod = 1000000007;
int v[maxn],num[maxn],vis[maxn],que1[maxn],que2[maxn];
int main()
{
freopen("equal.in","r",stdin);
freopen("equal.out","w",stdout);
int n;
scanf("%d",&n);
for(int i=1;i<=n;++i)
{
scanf("%d",&v[i]);
num[v[i]]++;
}
for(int i=1;i<=n;++i)
{
int tmp=v[i];
if(tmp!=1) vis[1]=1;
int ends=sqrt(tmp);
for(int j=2;j<=ends;++j)
{
if(tmp%j==0)
{
vis[j]=1;
vis[tmp/j]=1;
}
}
}
int pos1=0,pos2=0;
for(int i=1;i<=1000000;++i)
{
if(num[i]==0) continue;
int tmp=i;
if(vis[tmp])
{
que1[pos1++]=num[tmp];
}
que2[pos2++]=num[tmp];
}
sort(que1,que1+pos1);
sort(que2,que2+pos2);
//printf("%d****%d %d\n",pos1,que1[0],que1[1]);
int ans1=0,ans2=0,tmp1=0,tmp2=0;
printf("%d ",pos2);
for(int i=1;i<=n;++i)
{
tmp1+=1;
while(tmp1>=que1[ans1] && ans1<pos1)
{
tmp1-=que1[ans1];
ans1++;
} tmp2+=1;
while(tmp2>=que2[ans2] && ans2<pos2)
{
tmp2-=que2[ans2];
ans2++;
} if(i!=n)
printf("%d ",pos2-max(ans1,ans2-1));
else printf("%d\n",pos2-max(ans1,ans2-1));
}
return 0;
}
Equal Numbers Gym - 101612E 思维的更多相关文章
- Sheldon Numbers GYM -- 枚举
Sheldon Numbers GYM 题意:定义Sheldon Number为其二进制数是ABA……ABA型的或者ABAB……AB的,其中A全为1,B全为0(A>0, B>0),问[m, ...
- Codeforces gym101612 E.Equal Numbers(贪心)
传送:http://codeforces.com/gym/101612 题意:给出一个大小为n的序列a[i],每次选其中一个数乘以一个正整数,问进行k步操作后最少剩下多少种数字,输出0≤k≤n,所有的 ...
- Codeforces.GYM101612E.Equal Numbers(贪心)
题目链接 \(Description\) 给定\(n\)个数,每次可以将任意一个数乘上任意一个正整数. 求\(k\)次操作后,数列中数的种类最少可以是多少.对每个\(0\leq k\leq n\)输出 ...
- Random Numbers Gym - 101466K dfs序+线段树
Tamref love random numbers, but he hates recurrent relations, Tamref thinks that mainstream random g ...
- Gym - 101981E 思维
Gym - 101981EEva and Euro coins 题意:给你两个长度皆为n的01串s和t,能做的操作是把连续k个相同的字符反转过来,问s串能不能变成t串. 一开始把相同的漏看了,便以为是 ...
- equal numbers
给你一个n长度的数组,让你修改0到n次,问每次修改后能剩下不同个数的最小数是多少: 这里有了两种做法,一种是变成他们的lcm这样的话,修改后答案应该是减去改过的个数然后在加一 另一种就是数字修改成序列 ...
- Problem D. Berland Railroads Gym - 101967D (思维)
题目链接:https://cn.vjudge.net/contest/274029#problem/D 题目大意:给你0-9每个数的个数,然后让你找出最大的数,满足的条件是任意三位相连的都能被三整除. ...
- Numbers(CodeForces-128D)【思维/list】
题目链接:https://vjudge.net/problem/CodeForces-128D 题意:给出一组数,要求将这些数排列成一个环,满足每相邻两个数的差值为1,问能否完成. 思路:先取出最小的 ...
- Simple Robot Gym - 101102I (思维)
SaMer is building a simple robot that can move in the four directions: up (^), down (v), left (<) ...
随机推荐
- 【C++】《C++ Primer 》第十九章
第十九章 特殊工具与技术 一.控制内存分配 1. 重载new和delete new表达式的工作机理: string *sp = new string("a value"); //分 ...
- SpringBoot魔法堂:@MatrixVariable参数注解使用详解
前言 RFC3986定义URI的路径(Path)中可包含name-value片段,扩充了以往仅能通过查询字符串(Query String)设置可选参数的囧境. 假如现在需要设计一个用于"搜索 ...
- requests +httprunne r
1.get 请求和 post 请求的区别是什么? 2.requests 模拟 get 请求时,有哪两种方式让响应的结果不是乱码?(直接代码描述) 3.requests 库中的 post 方法,参数 ...
- uni-app开发经验分享十一: uniapp iOS云打包修改权限提示语
打包提交appstore如果用到了如下权限需要修改提示语,详细描述使用这个权限的原因,如不修改提示语appstore审核可能会被拒绝.Apple的原则是,如果一个app想要申请用户同意某个隐私信息访问 ...
- uni-app开发经验分享八: 实现微信APP支付的全过程详解
背景 最近项目使用uni-app实现微信支付,把过程简单记录下,帮助那些刚刚基础uni-app,苦于文档的同学们.整体来说实现过程和非uni-app的实现方式没有太大不同,难点就在于uni-app对于 ...
- 拒演"拼命工作"的苦情戏,如何更聪明地提高工作效率?
前几天PDD的事情又把互联网打工人的工作状态推向了大众视野,引起了大家的口诛笔伐.但是目前来看这种愤慨终究是暂时的,作用甚微.在大环境短时间无法改变的前提下,想想如何应对,或许比在网上愤愤不平破口大骂 ...
- Visual Studio中自定义代码段!
Visual Studio中自定义代码段! 第一步:在编辑器中进行快捷键的输入[ctrl + shift + p] 或者 点击 查看 第一个选项就是!请看下图 第二步:选择你要配置代码段的语言, 这里 ...
- jQuery 真伪数组的转换
//真数组转换伪数组 var arr = [1,3,5,7,9]; var obj = {}; [].push.apply(obj,arr); console.log(obj) //伪数组转真数组 v ...
- 如何实现new,call,apply,bind的底层原理。
new做了什么? new是用来实例化对象的,当new了一个对象后 1.创建一个新对象 2.将构造函数的作用域赋值给新对象(this指向新对象) 3.执行构造函数里面的代码(为这个新对象添加属性) 4. ...
- ChannelNets: 省力又讨好的channel-wise卷积,在channel维度进行卷积滑动 | NeurIPS 2018
Channel-wise卷积在channel维度上进行滑动,巧妙地解决卷积操作中输入输出的复杂全连接特性,但又不会像分组卷积那样死板,是个很不错的想法 来源:晓飞的算法工程笔记 公众号 论文: C ...