NOIP模拟题——细胞分裂

【问题描述】
小 A 养了一大坨细胞。 最初小 A 只有 1 个细胞。每秒,小 A 的每个细胞都会分裂成 2 个细胞。

已知:现在离“最初”已经过去了x秒,那么现在的细胞数当然是可以计算的。 小 A 想知道的当然不是当前的细胞数。小 A 知道他养的细胞的习性:每 y 个细胞会聚成一团。经常会有剩下的细胞,那么我们称这些细胞是孤独的。 小 A 想知道的就是孤独的细胞个数。
【输入文件】
输入文件为 cell.in。 输入文件共一行,为两个整数 xy,以空格隔开。
【输出文件】
输出文件为 cell.out。 输出文件共一行,为一个整数,即孤独的细胞个数。
【输入样例】

3 3
【输出样例】

2
【数据规模和约定】
对于 10%的数据,x<2^6。

对于 20%的数据,x<2^17。

对于 40%的数据,x<2^64。

对于 70%的数据,x<2^2333。

对于 100%的数据,0≤x<2^233333,y 是 3 到 1000 之间(含两端)的质数。

法1(70分):高精度+快速幂

 1 #include<cstdio>
 2 #include<iostream>
 3 #include<cstring>
 4 using namespace std;
 5 int x[300000],y[300000];
 6 int qwe;
 7 long long solve(int *x)
 8 {
 9     if((x[0]==0||x[0]==1)&&x[1]==1)return 2;
10     int pre=0;int temp=0;
11     bool pd=true;
12     if(x[1]/2!=0)temp++;
13     if(x[x[0]]%2==0)pd=false;//偶数
14     for(int i=1;i<=x[0];i++)
15     {
16         int k=pre*10+x[i];
17         y[temp++]=k/2;
18         pre=k%2;
19     }
20     if(x[1]/2!=0)y[0]=x[0];else y[0]=x[0]-1;
21     for(int i=1;i<=y[0];i++)
22     x[i]=y[i];
23     x[0]=y[0];
24     if(pd==true)//奇数
25     {
26         long long b=solve(x)%qwe;
27         b=b*b*2%qwe;
28         return b;
29     }
30     else
31     {
32         long long b=solve(x)%qwe;
33         b=b*b%qwe;
34         return b;
35     }
36 }
37 int main()
38 {
39     freopen("cell.in","r",stdin);
40     freopen("cell.out","w",stdout);
41     int temp=0;
42     char c=getchar();
43     while(c<‘0‘||c>‘9‘)c=getchar();
44     while(c>=‘0‘&&c<=‘9‘)
45     {
46         x[++temp]=c-‘0‘;
47         c=getchar();
48     }
49     x[0]=temp;
50     scanf("%d",&qwe);
51     long long ans=solve(x);
52     printf("%I64d",ans%qwe);
53     return 0;
54 }

法2:费马小定理:

假如p是质数,且gcd(a,p)=1,那么 a(p-1)≡1(mod p)。

#include<cstdio>
#include<iostream>
#include<cmath>
#include<cstring>
using namespace std;
char s[100005];int x,y;
void solve()
{
    char c;
    int len=strlen(s);
    for(int i=0;i<len;i++)
    {
        c=s[i];
        x=((c-‘0‘)+x*10)%(y-1);
    }
}

int main()
{
    freopen("cell.in","r",stdin);
    freopen("cell.out","w",stdout);
    scanf("%s %d",s,&y);
    solve();
    int ans=1;
    for(int i=1;i<=x;i++)
    ans=(ans*2)%y;
    printf("%d",ans);
}
时间: 2024-08-02 05:02:27

NOIP模拟题——细胞分裂的相关文章

[BZOJ入门OJ2092][Noip模拟题]舞会

2092: [Noip模拟题]舞会 Time Limit: 20 Sec  Memory Limit: 256 MB Submit: 9  Solved: 5 [Submit][Status][Web Board] Description 学校举行舞会啦,一共有N个人参加,所有人站成一排,从左开始编号,最左边的人编号为1 ,最右边的为N.每个人跳舞的熟练度我们用一个整数表示,第i个人的熟练度为Ai,每次熟 练度最接近的一对相邻男女会出列跳舞,如果有多对那么最左边的那一对会先出列,请你给 出出列跳

8.22 NOIP 模拟题

  8.22 NOIP 模拟题 编译命令 g++ -o * *.cpp gcc -o * *.c fpc *.pas 编译器版本 g++/gcc 4.9.2 fpc 2.6.2 评测环境 64 位 Linux, 3.3GHZ CPU 评测软件 Lemon 评测方式 忽略行末空格和回车 特别注意:c/c++ 选手使用 printf 输出 64 位整数请使用%lld 1 注意事项 A 债务 文件名                            输入文件             输出文件  

noip模拟题题解集

最近做模拟题看到一些好的题及题解. 升格思想: 核电站问题 一个核电站有N个放核物质的坑,坑排列在一条直线上.如果连续M个坑中放入核物质,则会发生爆炸,于是,在某些坑中可能不放核物质. 任务:对于给定的N和M,求不发生爆炸的放置核物质的方案总数 输入:输入文件只一行,两个正整数N,M( 1<N<50,2≤M≤5) 输出:输出文件只有一个正整数S,表示方案总数. 运用升格思想.设N个坑不会发生爆炸的方案数是f[N],那么我们假设N以前的坑的方案 都已知了,那么我们只需要考虑第N个坑如何放即可(顺

【NOIP2009】第三题&#183;细胞分裂

题目描述 Description Hanks 博士是BT (Bio-Tech,生物技术) 领域的知名专家.现在,他正在为一个细胞实验做准备工作:培养细胞样本.Hanks 博士手里现在有N 种细胞,编号从1~N,一个第i 种细胞经过1 秒钟可以分裂为Si 个同种细胞(Si 为正整数).现在他需要选取某种细胞的一个放进培养皿,让其自由分裂,进行培养.一段时间以后,再把培养皿中的所有细胞平均分入M 个试管,形成M 份样本,用于实验.Hanks 博士的试管数M 很大,普通的计算机的基本数据类型无法存储这

9.22 NOIP模拟题

吉林省信息学奥赛 2017 冬令营                                                                                                                                                                                                      day2 嗯 今天题目好水 嗯 今天爆零了好伤心...... 值得纪念

6.19 noip模拟题(题目及解析转自 hzwer 2014-3-15 NOIP模拟赛)

Problem 1 高级打字机(type.cpp/c/pas) [题目描述] 早苗入手了最新的高级打字机.最新款自然有着与以往不同的功能,那就是它具备撤销功能,厉害吧. 请为这种高级打字机设计一个程序,支持如下3种操作: 1.T x:在文章末尾打下一个小写字母x.(type操作) 2.U x:撤销最后的x次修改操作.(Undo操作) (注意Query操作并不算修改操作) 3.Q x:询问当前文章中第x个字母并输出.(Query操作) 文章一开始可以视为空串. [输入格式] 第1行:一个整数n,表

【noip模拟题】天神下凡(贪心)

vijos某次模拟赛原题... 处理出每个圆的一级祖先就行了... 其实没有那么麻烦,贪心即可出解. 我们将每个圆转换成线段后按左端点小右端点大的方法排序 然后维护一个栈: 对于每一个圆i 如果栈顶右端点比圆i的右端点小,则出栈,直到栈空 否则i的一级祖先就是栈顶,并且加入i到栈. 证明: 因为左端点排序,所以问题转换为找一个最小的右端点能够包含此线段 假如栈顶的右端点比当前右端点小,显然对于所有将来的线段,不可能包含将来的线段(或者说,尽管能,也不是最优解,因为最优解就是当前i) 然后如果有n

【noip模拟题】挖掘机(模拟题+精度)

这题直接模拟. 可是我挂在了最后两个点上QAQ.唯一注意的是注意精度啊...用来double后边转成整数就忘记用longlong...sad #include <cstdio> #include <cstring> #include <cmath> #include <string> #include <iostream> #include <algorithm> #include <queue> #include <

【noip模拟题】迎接仪式(dp+特殊的技巧)

好神的一题... 这是一道DP题,本题的难点在于状态的确定,由于调整是任意的,很难划分状态,我们略微修改一下调整的形式:把一次’j’和’z’交换看做两次变换:’j’->’z’;’z’->’j’ (zz交换和jj交换是没有意义的,不作考虑);于是最多’j’->'z' 'z'->'j'各K次. F[i,j,k]:=F[i-2,j-x,k-y]+1;If A[i-1]=j then x=0 else x=1If A[i]=z then y=0 else y=1 然后最后要看是否有那么多个