这次模拟赛真的,,卡常赛。

The solution of T1:

std是打表,,考场上sb想自己改进匈牙利然后wei了(好像匈牙利是错的。

大力剪枝搜索。代码不放了。

  

  这是什么神仙D1T1,爆蛋T1,好像A了它或拿分的就几个人,,


The solution of T2:

题解是这么写的:和八皇后很像,八皇后是x+y和x-y来判重,这里就k1x+k2y来判重。

从各个点引出直线,带入原点检验方程即可。

注:

x/y = Δx/Δy

x*Δy = Δx*y

下面代码用了这个原理,省去了gcd(或除法)的时间复杂度或精度问题

Code:

#include <cstdio>
#include <map>
#include <algorithm>

using namespace std;

;
map <long long,int> M[N];
map <long long,int> T;
int n,m,i,j,k,q,tx,ty,s,num;
int x[N],y[N],dx[N],dy[N];
bool pd;

?a:gcd(b,a%b);}
int main()
{
    freopen("laser.in","r",stdin);
    freopen("laser.out","w",stdout);
    scanf("%d",&n);
    ;i<=n;i++)
    {
        scanf("%d%d",&tx,&ty);
        ) tx=-tx,ty=-ty;
        y[i]=-tx,x[i]=ty;
        tx=abs(y[i]),ty=abs(x[i]),k=gcd(tx,ty);
        y[i]=y[i]/k,x[i]=x[i]/k;
        ;j<i;j++)
            if ((x[i]==x[j]) && (y[i]==y[j]))
            {
                i--,n--;
                break;
            }
    }
    scanf("%d",&m);
    ;i<=m;i++)
    {
        scanf("%d%d",&tx,&ty);
        ;j<=n;j++)
            M[j][1LL*tx*x[j]+1LL*ty*y[j]]++;
        T[tx*()+ty]++;
    }
    scanf("%d",&q);
    ;i<=q;i++)
    {
        s=;
        scanf("%d%d",&tx,&ty);
        ;j<=n;j++)
            s=s+M[j][1LL*tx*x[j]+1LL*ty*y[j]];
        s=s-(n-)*T[tx*()+ty];
        printf("%d\n",s);
    }
    ;
}

T2

  所以,我只拿了60分。神tmD1T2


 The solution of T3:

    剪枝细节,,一堆的。不过和D1T3难度低一点吧。

    考虑用 SPFA 迭代计算到达每个点存活且残余的最大 HP。(请注意加粗字体,旁边的大佬ldl因此 100->90 )
    考虑到 SPFA 本 身是一个广搜的过程,自然也可以类似广搜地统计最少时间。因此,直接跑 SPFA 即可。时间复杂度 O(EAns)。
 
    Code:
    

#include <cstdio>
#include <algorithm>

using namespace std;

],next[],dist[],first[];
],d[],g[],h[],p[],r[];
int i,k,m,n,x,y,z,head,tail,sum_edge;

int main()
{
    freopen("game.in","r",stdin);
    freopen("game.out","w",stdout);
    scanf("%d%d%d",&n,&m,&k);
    ;i<=n;i++)
        scanf("%d",&r[i]);
    ;i<=m;i++)
    {
        scanf("%d%d%d",&x,&y,&z);
        sum_edge++,edge[sum_edge]=y,next[sum_edge]=first[x],dist[sum_edge]=z,first[x]=sum_edge;
        sum_edge++,edge[sum_edge]=x,next[sum_edge]=first[y],dist[sum_edge]=z,first[y]=sum_edge;
    }
    d[]=p[]=k;
    tail++,g[tail]=,h[tail]=;
    ;head<=tail;head++)
    {
        if (g[head]==n)
        {
            printf("%d\n",h[head]);
            ;
        }
        ])
            for (i=head;i<=tail;i++)
                d[g[i]]=p[g[i]],b[g[i]]=;
        ;i=next[i])
            if ((d[g[head]]>dist[i]) && (min(d[g[head]]-dist[i]+r[edge[i]],k)>p[edge[i]]))
            {
                p[edge[i]]=min(d[g[head]]-dist[i]+r[edge[i]],k);
                if (! b[edge[i]])
                    tail++,g[tail]=edge[i],h[tail]=h[head]+,b[edge[i]]=;
            }
    }
    printf("-1\n");
    ;
}

代码是老师的

    

    这题我莫名从60/70 -> 30???

    

  神tmT1T2

2019.7.26 NOIP 模拟赛的更多相关文章

  1. 【2019.7.26 NOIP模拟赛 T3】化学反应(reaction)(线段树优化建图+Tarjan缩点+拓扑排序)

    题意转化 考虑我们对于每一对激活关系建一条有向边,则对于每一个点,其答案就是其所能到达的点数. 于是,这个问题就被我们搬到了图上,成了一个图论题. 优化建图 考虑我们每次需要将一个区间向一个区间连边. ...

  2. 【2019.7.26 NOIP模拟赛 T1】数字查找(figure)(数学)

    推式子 我们设\(n=kp+w\),则: \[(kp+w)a^{kp+w}\equiv b(mod\ p)\] 将系数中的\(kp+w\)向\(p\)取模,指数中的\(kp+w\)根据欧拉定理向\(p ...

  3. 【2019.8.20 NOIP模拟赛 T2】小B的树(tree)(树形DP)

    树形\(DP\) 考虑设\(f_{i,j,k}\)表示在\(i\)的子树内,从\(i\)向下的最长链长度为\(j\),\(i\)子树内直径长度为\(k\)的概率. 然后我们就能发现这个东西直接转移是几 ...

  4. 【2019.8.20 NOIP模拟赛 T3】小X的图(history)(可持久化并查集)

    可持久化并查集 显然是可持久化并查集裸题吧... 就是题面长得有点恶心,被闪指导狂喷. 对于\(K\)操作,直接\(O(1)\)赋值修改. 对于\(R\)操作,并查集上直接连边. 对于\(T\)操作, ...

  5. 【2019.7.20 NOIP模拟赛 T2】B(B)(数位DP)

    数位\(DP\) 首先考虑二进制数\(G(i)\)的一些性质: \(G(i)\)不可能有连续两位第\(x\)位和第\(x+1\)位都是\(1\).因为这样就可以进位到第\(x+2\)位.其余情况下,这 ...

  6. 【2019.7.20 NOIP模拟赛 T1】A(A)(暴搜)

    打表+暴搜 这道题目,显然是需要打表的,不过打表的方式可以有很多. 我是打了两个表,分别表示每个数字所需的火柴棒根数以及从一个数字到另一个数字,除了需要去除或加入的火柴棒外,至少需要几根火柴棒. 然后 ...

  7. 【2019.7.22 NOIP模拟赛 T1】麦克斯韦妖(demon)(质因数分解+DP)

    暴力\(DP\) 先考虑暴力\(DP\)该怎么写. 因为每个序列之后是否能加上新的节点只与其结尾有关,因此我们设\(f_i\)为以\(i\)为结尾的最长序列长度. 每次枚举一个前置状态,判断是否合法之 ...

  8. 【2019.7.25 NOIP模拟赛 T3】树(tree)(dfs序列上开线段树)

    没有换根操作 考虑如果没有换根操作,我们该怎么做. 我们可以求出原树的\(dfs\)序列,然后开线段树维护. 对于修改操作,我们可以倍增求\(LCA\),然后在线段树上修改子树内的值. 对于询问操作, ...

  9. 【2019.7.24 NOIP模拟赛 T1】道路建设(road)(水题)

    原题与此题 原题是一道神仙不可做题,两者区别在于,原题不能有重边和自环. 然而,这题可以有重边... 于是这题就变成了一道大水题. 此题的解法 考虑如何构造. 对于\(n\le10^4\)的情况: 对 ...

随机推荐

  1. JAVA线程同步通信

    以下讲解Lock线程同步通信,也是比synchronized强大的一个功能点 先看一个常规的案例: 用户类 public class Person { public void eat(){ for(i ...

  2. 《剑指offer》面试题3 二维数组中的查找 Java版

    (二维数组,每行递增,每列递增.输入二维数组和一个整数,判断数组中是否含有此数.) 我的方法:拿到题目,根据题目条件我提取出这样一个特性:一个数的右边和下面的数都比它大.于是就可以写出一种递归的方法: ...

  3. mysql 5.7 创建函数报错,This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration and binary logging is enabled (you *might* want to use the less safe log_bin_trust_function_creat

    今天用命令创建函数, 报错 This function has none of DETERMINISTIC, NO SQL, or READS SQL DATA in its declaration ...

  4. [CodeForces 52C]Circular RMQ

    题目传送门 评分:省选/NOI-,难度:普及+/提高 这题真的和RMQ没有半点关系,只需要一个裸的线段树,连pushdown都不需要,只需要两种操作:区间修改和区间求最小值,在回溯时加上标记即可,唯一 ...

  5. 关于plt.imshow()显示彩图问题

    https://blog.csdn.net/cnnmena/article/details/79613531

  6. python学习第十二天列表的循环,排序,统计操作方法

    python列表最重要的列表的循环,任何有序列表离不开循环,列表的循环 for  in  range等关键词,还有列表排序,正序,倒序,还有列表每个元素的最大,最小,统计元素的个数等. 1,列表的循环 ...

  7. python基础学习 day 1

    初学python,记录下自己的历程~ 了解了一下python的基本概念,现在使用的比较多的就是python2.7 学习了if语句和两个经典的循环语句 #关于if语句的应用 name = raw_inp ...

  8. 【转载】windows 开启 nginx 监听80 端口 以及 禁用 http 服务后,无法重启 HTTP 服务,提示 系统错误 123,文件目录、卷标出错

    https://www.cnblogs.com/TianyuSu/p/9509873.html location / { proxy_set_header Host $Host; proxy_set_ ...

  9. python时间的获取

    一.获取当前时间 import datetime # 2019-7-9 print(datetime.datetime.now().year) # 2019 print(datetime.dateti ...

  10. rabbitmq3.7集群搭建实战

    环境: 3台 centos7.4rabbitmq3.7erlang 22 1. 有几种方式安装,这里使用的yum安装(官方推荐)2. 使用rabbitmq时需要安装erlang,在各个节点上使用vim ...