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

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. [CF960G]Bandit Blues(第一类斯特林数+分治卷积)

    Solution: ​ 先考虑前缀,设 \(f(i, j)\) 为长度为 \(i\) 的排列中满足前缀最大值为自己的数有 \(j\) 个的排列数. 假设新加一个数 \(i+1\) 那么会有: \[ f ...

  2. Django读写分离

    多数据库配置 数据库配置 DATABASES = { 'default': { 'ENGINE': 'django.db.backends.sqlite3', 'NAME': os.path.join ...

  3. E Easy problem

    链接:https://ac.nowcoder.com/acm/contest/338/E来源:牛客网 Zghh likes number, but he doesn't like writing pr ...

  4. vue 实现模糊检索,并根据其他字符的首字母顺序排列

    昨天让我做一个功能,实现一个模糊检索,我就想,那做呗,然后开始正常的开发 代码如下: HTML VUE 因为是实时的,所以写了将逻辑写到了watch中 五分钟搞定.   我以为这就完了,然而产品的需求 ...

  5. JS高级 — 函数的声明和表达式

    <!DOCTYPE html> <html> <head> <meta charset="utf-8"> <meta http ...

  6. windows安装 阿里云的Fun工具

    由于项目使用到了 函数计算,特此了解到了需要安装 阿里云的Fun工具 Fun 是一个用于支持 Serverless 应用部署的工具,能帮助您便捷地管理函数计算.API 网关.日志服务等资源.它通过一个 ...

  7. DB count check for TABLES VIEWS PROCEDURES TRIGGERS

    SELECT DISTINCT(TABLESPACE_NAME) FROM ALL_TABLES; SELECT COUNT(*) FROM ALL_TABLES where TABLESPACE_N ...

  8. Informatica参考

    近日在做informatica项目时,要求参照informatica中原有的mapping方式实现.那么当知道源表或者目标表或者是映射时,如何快速的找出分散在不同的Subject的mapping或者是 ...

  9. bzoj4182 Shopping 点分治+单调队列优化多重背包

    题目传送门 https://lydsy.com/JudgeOnline/problem.php?id=4182 题解 有一个很直观的想法是设 \(dp[x][i]\) 表示在以 \(x\) 为根的子树 ...

  10. LOJ6252. 「CodePlus 2017 11 月赛」大吉大利,晚上吃鸡! 最短路+bitset

    题目传送门 https://loj.ac/problem/6252 https://lydsy.com/JudgeOnline/problem.php?id=5109 题解 首先跑最短路,只保留 \( ...