传送门——UOJ

传送门——Luogu


这段时间请不要找Itst聊天,Itst已经做疯了

事实证明大模拟题不可做

query 1

送分,加起来一起乘即可

I
I
+
<
-
O 

query 2

送分

I
-
<
+
S
O 

query 3

送分,把原数扩大$INF$倍,再调用$s$函数即可

默认下面的$INF=2^{100}$

I
<
S
C  -0.5
<
O 

query 4

好火啊qaq

因为我们的操作只允许我们放大到无穷大和缩小到趋近于$0$,所以我们考虑当$x$趋近于$0$时式子会趋向于什么

因为$s'(x) = ((1+e^{-x})^{-1}) ' = -(1+e^{-x})^{-2} \times (1+e^{-x})'$

$(1+e^{-x}) ' = (e^{-x}) ' = -e^{-x}$

所以$s'(x) = \frac{e^{-x}}{(1 + e^{-x})^2}$

将$0$带入得$s'(0)=\frac{1}{4}$

也就是说当$x$趋近于$0$时,函数可以近似为一个一次函数:$y=\frac{1}{4}x + 0.5$

而$s(x \times INF)$在$x<0$时等于$0$

所以不妨求$s(\frac{x}{INF} + INF \times s(x \times INF))$

如果$x<0$,括号内部的值趋向于$0$,得到的结果为$\frac{x}{4INF}+0.5$,那么取负、加上$0.5$、乘上$8INF$之后得到了$-2x$,加上$x$就得到了$-x$。

如果$x>0$,括号内部的值为$INF$,得到的结果为$1$。那么取负、加上$0.5$、乘上$8INF$、加上$x$之后得到了$4INF + x$,与我们需要的条件不符

那么我们只需要最后减去$4INF \times s(x \times INF)$即可满足条件了

当输入为$0$时会很尴尬地得到$0.5$的结果,我们只需要给$0$加上或减去$eps$就可以了

I
C  -0.0000000000000000000000001
<
S
<
>
+
S
-
C  0.5
<
+
+
O 

query 5

送分,模拟题,注意不要对$2^0$项左移即可

    freopen("nodes5.out" , "w" , stdout);
    queue < int > q;
    ;
     ; i >=  ; --i){
        puts("I");
        ++cnt;
        if(i)
            printf("< %d %d\n" , cnt++ , i);
        q.push(cnt);
    }
    ){
        printf("+ %d " , q.front());
        q.pop();
        printf("%d\n" , q.front());
        q.pop();
        q.push(++cnt);
    }
    printf("O %d\n" , q.front());

query 6

贼卡常

设$p$为当前数,$k$从$31$到$1$用$query\ 3$的方法检验$p-2^k$是否为正,如果为正减去$2^k$

$k=0$时可以直接输答案,无需判断。

考虑我们每一次使用$query\ 3$的方法时都需要乘上$INF$,常数太大,我们考虑在输入这个数据之后直接乘上$INF$,这样就不用每一次都左移。

使用浮点数计算二进制次幂。

可能会存在$p=2^k$,导致$s((p-2^k) \times INF)=0.5$的情况产生,我们只需要将$2^k -= eps$就不会有这种问题发生了。

    freopen("nodes6.out" , "w" , stdout);
    puts("I");
    puts("< 1 100");
    ;
     ; i >  ; --i){
        printf("C %d -%.7lf\n" , cur , pow(2.0 , i-0.0001));
        printf();
        printf();
        printf( , i);
        printf();
        printf();
        cur += ;
    }
    printf("> %d 100\n" , cur);
    printf();

query 7

实际上直接交样例可以在$Luogu$上$AC$,但是$UOJ\ Hack$了

用$query\ 6$的方法拆二进制,如果我们做按位加法,只有$11$不满足我们的要求

也就是说和为$2$时答案为$0$,否则和原来一样

设和为$x$,不难想到$ans=x +(-(s(x - 1.5) \times 2))$

    freopen("nodes7.out" , "w" , stdout);
    queue < int > que1 , que2 , que3;
    puts("I");
    puts("< 1 100");
    cur = ;
     ; i >  ; --i){
        printf("C %d -%.7lf\n" , cur , pow(2.0 , i-0.0001));
        printf();
        que1.push(cur + );
        printf( , i);
        printf();
        printf();
        cur += ;
    }
    printf("> %d 100\n" , cur);
    que1.push(cur + );
    puts("I");
    printf();
    cur += ;
     ; i >  ; --i){
        printf("C %d -%.7lf\n" , cur , pow(2.0 , i-0.00000000001));
        printf();
        que2.push(cur + );
        printf( , i);
        printf();
        printf();
        cur += ;
    }
    printf("> %d 100\n" , cur);
    que2.push(cur + );
    ++cur;
     ; i >=  ; --i){
        printf("+ %d %d\n" , que1.front() , que2.front());
        ++cur;
        que1.pop();
        que2.pop();
        printf("C %d -1.5\n" , cur++);
        printf("< %d 200\n" , cur++);
        printf("S %d\n" , cur++);
        printf("< %d 1\n" , cur++);
        printf("- %d\n" , cur++);
        printf( , cur);
        ++cur;
        if(i)
            printf("< %d %d\n" , cur++ , i);
        que3.push(cur);
    }
    ){
        printf("+ %d " , que3.front());
        que3.pop();
        printf("%d\n" , que3.front());
        que3.pop();
        que3.push(++cur);
    }
    printf("O %d\n" , que3.front());

query 8

考虑找到一个点$x0$使得$s'(x0)=0.1$

然后用跟$query\ 4$相似的方法,将$\frac{x}{INF}+x0$代入$s$就可以得到$0.1x0 + 0.1\frac{x}{INF}$

然后还原就可以了

关于这个$x0$我是直接蒯的数据可以二分求上面导数式子的零点

    freopen("nodes8.out" , "w" , stdout);
    puts("I");
    puts("> 1 96");
    puts("C 2 -0.9624236501192068949955178268487368462703686687713210393220363376803277");
    puts("S 3");
    puts("C 4 -0.2763932022500210303590826331268723764559381640388474275729102754589479");
    puts("< 5 95");
    puts("O 6");

query 9

使用冒泡排序(虽然我自己写的冒泡排序不知道怎么无限$WA$)

伪代码长这样:

 ->
     ->
        t = val[i] + val[j];
        val[j] = min(val[i]-val[j] , ) + val[j];
        val[i] = t - val[j];

然后考虑如何实现上面的min函数

跟$query\ 4$的实现很像:求$s(\frac{x}{INF} + INF \times s(x \times INF))$,减$0.5$,乘$4INF$,减$s(x\times INF)\times 2INF$即可

    freopen("nodes9.out" , "w" , stdout);
    ] = {};
     ; i <=  ; ++i){
        puts("I");
        num[i] = i;
    }
    cur = ;
     ; i <=  ; ++i){
         ; j <=  ; ++j){
            printf("+ %d %d\n" , num[i] , num[j]);
            printf("- %d\n" , num[i]);
            printf();
            printf();
            printf();
            printf();
            printf();
            printf();
            printf( , cur + );
            printf();
            printf();
            printf();
            printf();
            printf( , cur + );
            printf();
            printf();
            printf( , cur + );
            num[i] = cur + ;
            num[j] = cur + ;
            cur += ;
        }
    }
     ; i <=  ; ++i)
        printf("O %d\n" , num[i]);

query 10

TBC

调$query\ 9$调太久了,不想写了,然后就随便蒯了一份代码把结果蒯了

尾声

这题目真养生~

UOJ224 NOI2016 旷野大计算 构造、造计算机的更多相关文章

  1. [NOI2016]旷野大计算

    Subtask0 造计算机神题.给一个忠告:珍爱生命,远离旷野大计算...... 代码在这里:戳我 Subtask1 给定\(a,b\):求\(-2a-2b\). 熟悉操作环境:\([-(a+b)]& ...

  2. [JZOJ4763] 【NOIP2016提高A组模拟9.7】旷野大计算

    题目 题目大意 给你一个数列,有很多个询问,询问一段区间内,某个数乘它的出现次数的最大值,也就是带权众数. 思考历程 第一次看到这道题,立马想到了树套树之类的二位数据结构,发现不行.(就算可以也很难打 ...

  3. noi2016旷野大作战

    玩了差不多两个小时61分 大概第9个点可以再拿5-6分 但是挺麻烦的并不想搞.. 这道题还是比较考验智商的??以及对那个特殊的ln函数的应用 感觉题目出的挺好的 看了题解 发现第4个点的确我应该想不到 ...

  4. 【JZOJ4763】【NOIP2016提高A组模拟9.7】旷野大计算

    题目描述 输入 输出 样例输入 5 5 9 8 7 8 9 1 2 3 4 4 4 1 4 2 4 样例输出 9 8 8 16 16 数据范围 解法 离线莫队做法 考虑使用莫队,但由于在删数的时候难以 ...

  5. [luogu1737]旷野大计算

  6. Microsoft Azure 大计算 – 宣布收购 GreenButton

     数据以及令人不可思议的计算能力,正在改变我们日常业务的经营方式,从科学和工程到媒体和金融,各行各业的客户正逐渐意识到什么是可能的.我们对整个基因组进行分析,以研制新药物.我们构建金融和保险模型, ...

  7. 【XSY3413】Lambda - 造计算机初步——邱奇-图灵论题与lambda演算

    题意: 关于邱奇-图灵论题的一点思考 这道题起源于计算机科学史上一个非常著名的问题——邱奇-图灵论题,这个论题是可计算性理论的基石,关于它的思考与证明几乎贯穿了整个计算机科学史,涵盖了数学.算法理论. ...

  8. sql server 大数据, 统计分组查询,数据量比较大计算每秒钟执行数据执行次数

    -- 数据量比较大的情况,统计十分钟内每秒钟执行次数 ); -- 开始时间 ); -- 结束时间 declare @num int; -- 结束时间 set @begintime = '2019-08 ...

  9. NOI2010~NOI2018选做

    [NOI2010] [NOI2010]海拔 高度只需要0/1,所以一个合法方案就是一个割,平面图求最小割. [NOI2010]航空管制 反序拓扑排序,每次取出第一类限制最大的放置,这样做答案不会更劣. ...

随机推荐

  1. lcn 分布式事务协调者集群原理

    lcn集群原理图: 1.实现原理: 1.1 LCN获取tm协调者注册地址 1. LCN客户端项目启动的时候,首先会注册到事务协调者中去,然后读取配置文件tm事务协调者的注册地址. 2. 向该事务协调者 ...

  2. html中用href 实现点击链接弹出文件下载对话框

    浏览器支持能够打开的格式,他都会默认直接在线打开(比如word或图片),不支持的格式,他就会弹出下载提示.最好是做成.rar格式.xlsx的文件.浏览器自带下载功能. <body> < ...

  3. 从零开始学习html(二)认识标签(第一部分)——下

    八.<blockquote>标签,长文本引用 <!DOCTYPE HTML> <html> <head> <meta http-equiv=&qu ...

  4. JavaScript 字符串转json格式

    第一种:浏览器支持的转换方式(Firefox,chrome,opera,safari,ie)等浏览器: JSON.parse(jsonstr); //可以将json字符串转换成json对象 JSON. ...

  5. Flutter 布局(十)- ListBody、ListView、CustomMultiChildLayout详解

    本文主要介绍Flutter布局中的ListBody.ListView.CustomMultiChildLayout控件,详细介绍了其布局行为以及使用场景,并对源码进行了分析. 1. ListBody ...

  6. system.transfer.list深度解析

    system.transfer.list  system.new.dat 很明显,通过名字我们就知道这两个文件的作用,system.new.dat为数据部分,system.transfer.list为 ...

  7. Lucene创建索引流程

    1.创建索引流程 原始文档:互联网上的网页(爬虫或蜘蛛).数据库中的数据.磁盘上的文件 创建文档对象(非结构化数据) 文档对象中的属性不叫属性现在成为域. 每个 Document 可以有多个 Fiel ...

  8. forfiles命令详解

    目录复制命令: xcopy   //server/bak/*.*    d:/serverbak /s /e /v /c / d /y /h             at 05:30 shutdown ...

  9. MySQL 8.0 —— 数据字典

    1.简介 MySQL 8.0 将数据库元信息都存放于InnoDB存储引擎表中,在之前版本的MySQL中,数据字典不仅仅存放于特定的存储引擎表中,还存放于元数据文件.非事务性存储引擎表中.本文将会介绍M ...

  10. Centos7.5调试/etc/sysctl.conf文件导致宕机

    今天安装greenplus数据库,需要调试一个核心文件/etc/sysctl.conf文件,结果导致系统异常宕机,出现的问题就是使用任何命令都不能输出正确的结果,只有这个显示: 不知道是什么原因,ls ...