尽管T1T2很简单,但还是阻止不了我T3wa一片

细胞分裂【题目链接】


xcg同学有一个80pts的代码

他说他的代码和我的很像,可惜我比较笨,只有30pts

其实这道题考场上是想到要分解质因数了,然后我质数表都打好了,但是不知道怎么记录乱七八糟的东西,然后就只会打暴力惹qwq

代码能力还是有待提升啊qwq


关于思路,就是上面所说的分解质因数,我们在分解质因数时,也只需要分解m1而不需要去分解m1m2,因为分解完质因数之后,对于它的m2次方,每个质因数的个数(也就是指数)都是m1所对应的这个质因数的个数(指数)*m2(应该是可以理解的哈)

其实当分解完样例的质因数就会豁然开朗的,除了你不会写之外,数学部分绝对是很容易理解的。

首先如果a%b==0,那么a的质因数中一定含有b所有的因数(当然b不一定含有a所有的因数),放到这个题中就是输入的数si的某次方一定含有m1m2的所有因数,当si所含的某个因数j的数量cnt1<m1m2中所含的j因数数量cnt2时,我们需要通过*si来使si的j因数数量>=m1m2中所含的j因数数量cnt2。这就是本题的基本思路。

其实思路都好说,然后代码实现是最神(dan)奇(teng)的;(咱就是因为不会实现然后才写暴力的)

首先开一个结构体,结构体中的变量:

cnt 记录某个数的质因数个数

pn[maxn]记录每个质因数的值

t[maxn]记录每个质因数的指数(也就是有多少个此质因数)

然后有两个结构体变量:

p,q;分别记录m1的质因数分解情况,输入的某个数si的质因数分解情况

然后是zysfj,具体的为啥真的不想写了,看代码+注释吧(当然也可以打表质数求qwq)

inline void fenjie(int t,prime& p)//质因数分解
{
p.cnt=;
for(int i=;i*i<=t;++i)
//至于为什么我们可以不用去枚举质数而是枚举每个数是因为如果某个合数是它的因数
//那么这个合数一定可以看成几个质数的乘积,因此只有质数才起到被分解的效果
{
if(!(t%i))//如果某个数是t的因数
{
p.pn[++p.cnt]=i;//记录第cnt个约数
p.t[p.cnt]=;
do//记录某个约数的个数
{
t/=i;
++p.t[p.cnt];//次数
}while(!(t%i));
}
} if(t>){//如果枚举到最后t大于1,那么此时的t值就是最后一个约数
p.pn[++p.cnt]=t;
p.t[p.cnt]=;
}
}

最后是main函数处理部分:

首先有一个特殊情况,那就是m1==1的情况,此时无论m2等于多少,都不需要分裂就可以得到满足题意的细胞数(如果不特判好像会一直循环然后TLE掉)

首先定义ans=-1(这样不更新的话就可以直接输出-1啦),

然后对于每输入的一个数,都先进行质因数分解,存到q中,然后几个判断退出的情况:

  • 我们知道将一个数乘方之后,乘方后的质因数与乘方前的质因数不同在于指数不同,而不会平白无故多出一些其他质因数,因为题目要求m1m2∣sit因此m1中所有的质因数si都必须要有至少一个,那么假设我们分解完si的质因数之后,发现si的质因数个数<m1的质因数个数,那么说明m1一定有si没有的质因数,那么无论怎样乘方,都无法达成m1m2∣sit,可以直接break掉;
  • 当第一个条件满足之后,就可以开始枚举m1与si的质因数了,首先枚举m1的每一个质因数(这里的质因数应该是从小到大排列的),用while循环来找出si中第一个>=(当前枚举的m1某个质因数)的质因数,显然因为分解时我们是从小到大枚举的,因此储存质因数也是从小到大,这样用while循环寻找后,如果找到的si的质因数>m1的质因数,也就说明si不含有m1的某个质因数,永远无法均分,所以可以直接退出(当然还有找遍整个循环也没有找到某个质因数的情况)

当我们在si中找到了m1的某个质因数,为了满足整除的条件,sit所含的此质因数的个数(也就是指数)必须要大于m1m2所含的质因数个数(指数),那么就可以:

分裂次数=m1的某个质因数个数*m2/si对应的此质因数个数(每次分裂都相当于乘一个si),然后向上取整(保证不会出现整除小1的情况)

对于m1的每一个质因数都要进行此操作,寻找一个最大值(因为最后要保证sit每个质因数指数都大于等于m1^m2)

然后对于每个si,记录每个si如果要整除m1^m2要乘方次数的最小值,最后输出这个最小值(如果没有满足条件的就输出‘-1’);

以下是完整CODE:(from ych)

#include<bits/stdc++.h>

using namespace std;

inline int read(){
int ans=;
char last=' ',ch=getchar();
while(ch<''||ch>'') last=ch,ch=getchar();
while(ch>=''&&ch<='') ans=ans*+ch-'',ch=getchar();
if(last=='-') ans=-ans;
return ans;
} struct prime{
int cnt,pn[],t[]/*t[i],第i个质因数的次数*/;
}p,q;//一个储存题目给的条件,一个储存判断
int n,m1,m2; inline void fenjie(int t,prime& p){//质因数分解
p.cnt=;
for(int i=;i*i<=t;++i){
//至于为什么我们可以不用去枚举质数而是枚举每个数是因为如果某个合数是它的因数
//那么这个合数一定可以看成几个质数的乘积,因此只有质数才起到被分解的效果
if(!(t%i)){//如果某个数是t的因数
p.pn[++p.cnt]=i;//记录第cnt个约数
p.t[p.cnt]=;
do{//记录某个约数的个数
t/=i;
++p.t[p.cnt];//次数
}while(!(t%i));
}
} if(t>){//如果枚举到最后t大于1,那么此时的t值就是最后一个约数
p.pn[++p.cnt]=t;
p.t[p.cnt]=;
}
}
int main(){
n=read(),m1=read(),m2=read();
if(m1==) return cout<<<<endl,;//先判断一波特殊情况
fenjie(m1,p);//把m1分解,存到p里
int ans,x;
ans=-;
for(int i=;i<=n;i++){
x=read();
fenjie(x,q);
int maxn=,nxt=;
//我们用nxt来存储x的下一个质因子的序号 bool flag=false; if(q.cnt>=p.cnt)
//只有要求判断的数的质因子的个数>=题目给的条件的质因子的个数才能继续
for(int j=;j<=p.cnt;j++){//枚举m1的每一个质因子 while(q.pn[nxt]<p.pn[j]&&nxt<=q.cnt)++nxt; if(nxt>q.cnt||q.pn[nxt]>p.pn[j])break;//如果没有这个质因子就跳出 int f=p.t[j]*m2/*m1^m2中含有多少个数值为p.pn[j]的因子*//q.t[nxt]; if((p.t[j]*m2)%(q.t[nxt])) f++;
//让这两个次数相等,因为有可能不整除,所以还要判断一下,相当于向上取整 if(maxn<f)maxn=f;//求最大值 if(j==p.cnt) flag=; //标记答案 else flag=;
} if(flag&&(ans==-||ans>maxn))ans=maxn;
} printf("%d\n",ans); return ;
}
#include<iostream>
#include<cstdio>
#include<algorithm>
#include<cstring>
#include<string>
#include<cmath> using namespace std; int db[]={,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,,};
int n,m1,m2,s,ans; struct node{
int cnt,pn[],num[];
}p,q; inline void fjzys(int a,node& g){
for(int i=;i<&&a;i++){
if(a%db[i]!=) continue;
g.pn[++g.cnt]=db[i];
while(!(a%db[i])){
a/=db[i];
g.num[g.cnt]++;
}
}
} int main(){
scanf("%d",&n);
scanf("%d %d",&m1,&m2);
if(m1==){
cout<<<<endl;return ;
}
fjzys(m1,p);ans=-;
for(int i=;i<=n;i++){
scanf("%d",&s);
memset(q.num,,sizeof(q.num));
memset(q.pn,,sizeof(q.pn));
q.cnt=;
fjzys(s,q);
bool flag=;
if(q.cnt<p.cnt) continue;
int cnt1=,maxn=;
for(int j=;j<=p.cnt;j++){
while(q.pn[cnt1]<p.pn[j]&&cnt1<=q.cnt) cnt1++;
if(q.pn[cnt1]>p.pn[j]||cnt1>q.cnt) break;
int f=p.num[j]*m2/q.num[cnt1];
if((p.num[j]*m2)%(q.num[cnt1])) f++;
if(f>maxn) maxn=f;
if(j==p.cnt) flag=;
}
if(flag==&&(ans==-||ans>maxn)) ans=maxn;
}
cout<<ans<<endl;
}

混迹其中

大概的思路就是这样啦;

end-

【6.18校内test】T3细胞分裂的更多相关文章

  1. #include <NOIP2009 Junior> 细胞分裂 ——using namespace wxl;

    题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细胞实 验做准备工作:培养细胞样本. Hanks 博士手里现在有 N 种细胞,编号从 1~N,一个 ...

  2. 洛谷 P1069 细胞分裂 解题报告

    P1069 细胞分裂 题目描述 \(Hanks\)博士是\(BT\) (\(Bio-Tech\),生物技术) 领域的知名专家.现在,他正在为一个细胞实验做准备工作:培养细胞样本. \(Hanks\) ...

  3. #include &lt;NOIP2009 Junior&gt; 细胞分裂 ——using namespace wxl;

    题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细胞实 验做准备工作:培养细胞样本. Hanks 博士手里现在有 N 种细胞,编号从 1~N,一个 ...

  4. P1069 细胞分裂

    P1069 细胞分裂 考虑质因数分解 先将m1,质因数分解后再根据数学定理将所有质数的质数全乘m2 然后将输入的数据相同处理,再判断 顺便说一下判断规矩 1肯定不行 如果分解后有没有m1质因数分解中的 ...

  5. luogu P1069 细胞分裂

    题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细胞实 验做准备工作:培养细胞样本. Hanks 博士手里现在有 N 种细胞,编号从 1~N,一个 ...

  6. 细胞分裂(洛谷 P1069)

    题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细胞实 验做准备工作:培养细胞样本. Hanks 博士手里现在有 N 种细胞,编号从 1~N,一个 ...

  7. cogs 466. [NOIP2009] 细胞分裂

    466. [NOIP2009] 细胞分裂 ★★   输入文件:cell.in   输出文件:cell.out   简单对比时间限制:1 s   内存限制:128 MB [问题描述]    Hanks ...

  8. 洛谷—— P1069 细胞分裂

    https://www.luogu.org/problem/show?pid=1069#sub 题目描述 Hanks 博士是 BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细 ...

  9. 【p093】细胞分裂

    Time Limit: 1 second Memory Limit: 128 MB [问题描述] Hanks博士是BT(Bio-Tech,生物技术)领域的知名专家.现在,他正在为一个细胞实验做准备工作 ...

随机推荐

  1. Confluence 6 预览一个文件

    当你浏览一个页面的时候,单击一个图片,文件缩略图或者链接将会运行预览. 预览视图包括了从远程 Web 页面导入的图片文件和已经附加到页面中的文件(尽管有可能这些文件没有在页面中显示). 在预览中你可以 ...

  2. Jmeter(三) 从上传图片来入门Jmeter

    用Jmeter上传用户头像到人人网 先用抓包工具Fiddler把上传操作的报文抓取下来 开启Jmeter,在测试计划中创建一个线程组,取名为“图片上传” 再在线程组中创建一个HTTP请求 在请求报文中 ...

  3. TreeMap元素必须实现Comparable接口

    纠正一下,TreeMap实现一定顺序是通过Comparable接口的,而他实现元素不重复也是完全通过compareTo,而不是hashCode和equals,因为debug不会走到hashCode和e ...

  4. vue.js环境安装

    1.到官网(http://nodejs.cn/download/)下载Node.JS运行环境并安装(由于现在的Node中自带npm包管理器,所以就不需要额外下载npm了) 2.如果是新手,那么建议以引 ...

  5. PHP CI 框架简单使用(二)

    我们简单认识一下CI框架的MVC.示例代码如下 //CI控制器文件Home.php <?php defined('BASEPATH') OR exit('No direct script acc ...

  6. SQL server中的一些查询

    SQL 不同于与其他编程语言的最明显特征是处理代码的顺序.在大数编程语言中,代码按编码顺序被处理,但是在SQL语言中,第一个被处理的子句是FROM子句,尽管SELECT语句第一个出现,但是几乎总是最后 ...

  7. golang 开源项目: 配置解析模块--config

    在golang中,配置文件经常使用json格式.json格式的语法,有些繁琐,尤其是出现嵌套的时候,每一块都需要大括号包裹,看起来很臃肿. 本着简单易用的原则,个人开发了一个配置解析模块config, ...

  8. leetcode 72. 编辑距离

    /***** 定义状态: DP[i][j]其中i表示word1前i个字符,j表示Word2前i个字符 DP[i][j]表示单词1前i个字符匹配单词2前j个字符,最少变换次数: 状态转移: for i: ...

  9. U盘无法拷贝大于4G的文件解决办法汇总

    U盘主要有三种格式: FAT32: 缺点:单个文件不能超过4GB,不支持512MB以下容量的U盘 备注:如果U盘容量达8GB以上,发现4GB文件拷不进去的话,可以考虑换用NTFS或ExFAT格式了 ● ...

  10. okgo网络请求框架的实现

    第一步:添加依赖: implementation 'com.lzy.net:okgo:3.0.4' implementation 'com.lzy.net:okrx2:2.0.2' implement ...