Link

  https://jzoj.net/senior/#main/show/3456

Description

  终于,在众亲们的奋斗下,最终boss 恭介被关进了库特设计的密室。正当她们松了一口气时,这个世界却发生了天翻覆地的变化:地面开始下沉,天空开始变成血红色,海水沸腾……一幅世界末日的图景。美鱼从她手中的古籍《若山牧水诗歌集》中发现了原因:白鸟は かなしからずや 空の青 海のあをにも 染まずただよふ 。大(xia)意(shuo)就是狡猾的恭介在创造这个世界的时候就篡改了法则。而这个法则的起源,就是一只生死之间的猫。这个猫被关在一个黑盒子里,盒子里有两个毒气罐,如果有任意一个毒气罐被打开那么猫将会被杀死,法则也能得到纠正。然而外界能控制的仅仅是这两个毒气罐被打开的概率。假设第一个毒气罐被打开的概率为1/x,第二个毒气罐为1/y(x,y 为正整数),那么当两个概率和为1/(n!)时,猫将会被莫名其妙地杀死。现在美鱼想知道,有多少对(x,y)可以让猫被莫名其妙杀死。

Solution

  其实,题目大意可以直接转化成如下一句精炼的话。

  

30分

  显然,因为n太小了,最大只有6,打表都行了,反正我考试时n=6也超时。。

60分

  正解+傻到没打高精度,或者打表。

100分

  我们分解一下题目给出的式子,详见下面过程及讲解

  合并左边的分式可得

  

  通过交叉相乘可得

  

  通过乘法分配律的逆运算得

  

  移项得

  

  通过合并式子得

  

  移项得

  

  分解到这里,我们可以推出下面的式子

  

  x同样可以这样证出来,我考试一直在证这个,其实还是有些乱用的,但是后面才是重点

  根据数学归纳,可以得知,x或y的最大值为n!(n!+1),虽然这没什么卵用

  我们枚举y来确定x,显然

  

  我们将y表示为一般的形式,即y=n!+k(k代表任意符合条件的数),带入前面的式子中,得

  

  合并同类项化简得  

  

  因为x是整数,所以n!n!+kn!必定为k的倍数,因为kn!是k的倍数,故不必考虑第二个多项式,我们只要考虑第一个多项式,即满足如下条件

  

  这样,答案就转化成求n!n!的约数个数了

  快速求n!的约数个数和分解质因子出来的式子(包括质因子和其指数),可以看我写的博客,链接如下

  (当成这里是有链接)

  显然,我们知道一个数分解质因子出来的式子,那么这个数的平方的式子同样可以得出来,不过就是指数都乘2罢了

  约数个数的公式就不用说了吧,小学一年级我就会了。

  这里算约数个数需要高精度。

  因为有时间限制,所以高精度要加常数优化,诸如低精度乘高精度,压位,延迟去乘法等

  问题迎刃而解了,考试时我以为很屌很屌,实际上真的很屌很屌,我数学不好,特别是这种分解的然后用的数代替成一般形式的,Orz lyl,dyp,wmz大佬

Code

var
now:int64;
n,i,j,num,tot:longint;
a:array[..] of int64;
bz:array[..] of ..;
procedure gg(x:int64);
var
i,len:longint;
begin
for i:= to a[] do
a[i]:=a[i]*x; len:=a[];
i:=; while i<=len do
begin
a[i+]:=a[i+]+a[i] div ;
a[i]:=a[i] mod ; if (a[i+]>) and (i+>len) then
inc(len); inc(i);
end; a[]:=len;
end;
begin
readln(n); a[]:=;
a[]:=;
now:=; for i:= to n do
if bz[i]= then
begin
for j:= to n div i do
bz[i*j]:=; num:=n;
tot:=; while num>=i do
begin
num:=num div i; inc(tot,num);
end; tot:=tot*+; if now*tot> then
begin
gg(now); now:=;
end; now:=now*tot; end; if now<> then
gg(now); write(a[a[]]); for i:=a[]- downto do
if a[i]>= then write(a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
if a[i]>= then write('',a[i]) else
write('',a[i]);
end.

[jzoj]3456.【NOIP2013模拟联考3】恭介的法则(rule)的更多相关文章

  1. JZOJ【NOIP2013模拟联考14】隐藏指令

    JZOJ[NOIP2013模拟联考14]隐藏指令 题目 Description 在d维欧几里得空间中,指令是一个长度为2N的串.串的每一个元素为d个正交基的方向及反方向之一.例如,d = 1时(数轴) ...

  2. JZOJ 3493. 【NOIP2013模拟联考13】三角形

    3493. [NOIP2013模拟联考13]三角形(triangle) (File IO): input:triangle.in output:triangle.out Time Limits: 10 ...

  3. JZOJ 3487. 【NOIP2013模拟联考11】剑与魔法(dragons)

    3487. [NOIP2013模拟联考11]剑与魔法(dragons) (Standard IO) Time Limits: 1000 ms  Memory Limits: 131072 KB  De ...

  4. JZOJ 3470. 【NOIP2013模拟联考8】最短路(path)

    470. [NOIP2013模拟联考8]最短路(path) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  5. JZOJ 3463. 【NOIP2013模拟联考5】军训

    3463. [NOIP2013模拟联考5]军训(training) (Standard IO) Time Limits: 2000 ms  Memory Limits: 262144 KB  Deta ...

  6. JZOJ 3462. 【NOIP2013模拟联考5】休息(rest)

    3462. [NOIP2013模拟联考5]休息(rest) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Detailed ...

  7. JZOJ 3461. 【NOIP2013模拟联考5】小麦亩产一千八(kela)

    3461. [NOIP2013模拟联考5]小麦亩产一千八(kela) (Standard IO) Time Limits: 1000 ms  Memory Limits: 262144 KB  Det ...

  8. 【NOIP2013模拟联考7】OSU

    [NOIP2013模拟联考7]OSU 描述 Description osu 是一款群众喜闻乐见的休闲软件. 我们可以把osu的规则简化与改编成以下的样子: 一共有n次操作,每次操作只有成功与失败之分, ...

  9. [jzoj]3468.【NOIP2013模拟联考7】OSU!(osu)

    Link https://jzoj.net/senior/#main/show/3468 Description osu 是一款群众喜闻乐见的休闲软件. 我们可以把osu的规则简化与改编成以下的样子: ...

随机推荐

  1. echarts 修改y轴刻度间隔问题

    其中min.max可以自定义可以动态获取数据 yAxis : [ {                        type : 'value',                        axi ...

  2. [TJOI2007] 调整队形

    题目链接 区间 DP 的经典模型之一. 题意是将整个串通过四种操作变成一个回文串,根据套路,不难设计出 dp[i][j] 表示为使区间 [i, j] 成为回文串的最少操作次数. 先判断 a[i] 是否 ...

  3. [JDK8]读写锁的改进:StampedLock

    StampedLock是Java8引入的一种新的锁机制,简单的理解,可以认为它是读写锁的一个改进版本,读写锁虽然分离了读和写的功能,使得读与读之间可以完全并发,但是读和写之间依然是冲突的,读锁会完全阻 ...

  4. 第十一节:Bundles压缩合并js和css及原理分析

    一. 简介 1.背景:浏览器默认一次性请求的网络数是有上限的,如果你得js和css文件太多,就会导致浏览器需要多次加载,影响页面的加载速度, MVC中提供Bundles的方式压缩合并js和css,是M ...

  5. react实战项目开发(1) 搭建react开发环境初始化项目(Create-react-app)

    前言 Create React App npm install -g create-react-app create-react-app my-app cd my-app npm start 执行命令 ...

  6. du---查看文件夹大小-并按大小进行排序

    使用df 命令查看当前磁盘使用情况: df -lh [root@gaea-dev-xjqxz-3 ~]$ df -lh Filesystem Size Used Avail Use% Mounted ...

  7. 如何让vue项目兼容IE浏览器

    一般来说项目开发到后期都需要做各种兼容性处理例如:360.IE9以上.QQ浏览器....等等 那么现在来介绍一个工具 babel-cli 跟 babel-preset-es2015 babel-cli ...

  8. 关于简单的安卓APP状态栏设置(类似沉浸式状态栏)

    1.设置为全屏模式: 在所需设置为全屏模式的逻辑的onCreat()方法中加入以下代码即可: if (Build.VERSION.SDK_INT >= Build.VERSION_CODES.K ...

  9. Haystack-全文搜索框架

    Haystack 1.什么是Haystack Haystack是django的开源全文搜索框架(全文检索不同于特定字段的模糊查询,使用全文检索的效率更高 ),该框架支持Solr,Elasticsear ...

  10. TF-tf.arg_max 介绍

    定义为 def arg_max(input, dimension, name=None) 作用是取行或者列的最大值的位置. input:类型为 float32, float64, int64, int ...