首页 > 其他分享 >《看了受制了》第二十三天,4道题,合计107道题

《看了受制了》第二十三天,4道题,合计107道题

时间:2023-09-23 09:45:02浏览次数:43  
标签:道题 return 第二十三 int res ll include 107 Mod

2023年9月22日

哎,再一次意识到弱小。。

Acwing1127 香甜的黄油

题目理解

n遍最短路,求出每个点到某个点到所有牧场的最短路即可。

代码实现

#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <vector>
#include <queue>
#include <unordered_map>
#include <set>
#define x first
#define y second
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;

const int Mod = 1e9 + 7, N = 810, M = 3000;
const int INF = 0x3f3f3f3f;

ll qmi(ll a, ll b)
{
    ll res = 1;
    while (b)
    {
        if (b & 1)
            res = res * a % Mod;
        a = a * a % Mod;
        b >>= 1;
    }
    return res;
}

ll inv(ll x) { return qmi(x, Mod - 2); }
ll mo(ll x) { return (x % Mod + Mod) % Mod; }

int h[N], e[M], ne[M], w[M], idx;
int p, n, k;
int id[N];
int d[N], q[M];
bool st[N];

int spfa(int u)
{
    memset(d, INF, sizeof d);
    memset(st, 0, sizeof st);

    int hh = 0, tt = 1;

    d[u] = 0;
    q[0] = u;
    st[u] = true;


    while(hh != tt)
    {
        int t = q[hh++];
        if(hh == N) hh = 0;
        st[t] = false;
        for(int i = h[t]; i != -1; i = ne[i])
        {
            int j = e[i];


            if(d[j] > d[t] + w[i])
            {
                d[j] = d[t] + w[i];
                if(!st[j])
                {
                    q[tt++] = j;
                    if(tt == N) tt = 0;
                    st[j] = true;
                }
            }

        }
    }

    int sum = 0;

    for(int i = 1; i <= p; i++)
    {
        if(d[id[i]] == INF) return INF;

        sum += d[id[i]];
    }
    return sum;
}

void add(int a, int b, int c)
{
    e[idx] = b, ne[idx] = h[a], w[idx] = c, h[a] = idx++;
}
int ans = INF;
int main()
{
    memset(h, -1, sizeof h);

    scanf("%d%d%d", &p, &n, &k);

    for(int i = 1; i <= p; i++)
        scanf("%d", &id[i]);

    for(int i = 1; i <= k; i++)
    {
        int a, b, c;
        scanf("%d%d%d", &a, &b, &c);

        add(a, b, c);
        add(b, a, c);
    }

    for(int i = 1; i <= n; i++)
        ans = min(ans, spfa(i));

    printf("%d", ans);
    return 0;
}

Acwing 1126最小花费

题目理解

因为每次会扣除手续费那么比如x元,就是x * (1 - rate1) * (1 - rate2) * (1 - rate3) ... ,这样下去。那么我们就需要。

\[max\prod_{i=1}^n{(1 - rate_i)} \]

其实就是乘积的最大路,然后让100 / rate积即可。

代码实现

#include <iostream>
#include <algorithm>
#include <cstring>
#include <cstdio>
#include <vector>
#include <queue>
#include <unordered_map>
#include <set>
#define x first
#define y second
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;

const int Mod = 1e9 + 7, N = 2010;
const int INF = 0x3f3f3f3f;

ll qmi(ll a, ll b)
{
    ll res = 1;
    while (b)
    {
        if (b & 1)
            res = res * a % Mod;
        a = a * a % Mod;
        b >>= 1;
    }
    return res;
}

ll inv(ll x) { return qmi(x, Mod - 2); }
ll mo(ll x) { return (x % Mod + Mod) % Mod; }

double g[N][N];
int n, m;
double d[N];
bool st[N];

double dijkstra(int a, int b)
{

    d[a] = 1;

    for(int i = 1; i <= n; i++)
    {
        int t = -1;
        for(int j = 1; j <= n; j++)
            if(!st[j] && (t == -1 || d[j] > d[t]))
                t = j;

        st[t] = true;

        for(int j = 1; j <= n; j++)
            d[j] = max(d[j], d[t] * g[t][j]);
    }

    return d[b];
}

int main()
{
    cin >> n >> m;

    for(int i = 1; i <= m; i++)
    {
        int a, b, c;
        cin >> a >> b >> c;
        double z = (100.0 - c) / 100;
        g[a][b] = g[b][a] = max(g[a][b], z);
    }
    int a, b;
    cin >> a >> b;
    double rate = dijkstra(a, b);

    printf("%.8lf",  100 / rate);
    return 0;
}

Acwing920 最优乘车

题目理解

这个题的建图方式比较特殊,要按照公交车的路线去建图。而且能到哪个?每个站台都要建图。
比如4 5 6 7,就要4 5\ 4 6\ 4 7\ 5 6\ 5 7\ 6 7\都进行建边,这样就可以求出1n站的最小乘车次数,那么最小的转车次数就是最小乘车次数 - 1。

代码实现

#include <iostream>
#include <algorithm>
#include <cstring>
#include <sstream>
#include <cstdio>
#include <vector>
#include <queue>
#include <unordered_map>
#include <set>
#define x first
#define y second
using namespace std;
typedef long long ll;
typedef pair<int, int> PII;

const int Mod = 1e9 + 7, N = 510;
const int INF = 0x3f3f3f3f;

ll qmi(ll a, ll b)
{
    ll res = 1;
    while (b)
    {
        if (b & 1)
            res = res * a % Mod;
        a = a * a % Mod;
        b >>= 1;
    }
    return res;
}

ll inv(ll x) { return qmi(x, Mod - 2); }
ll mo(ll x) { return (x % Mod + Mod) % Mod; }

int g[N][N], d[N] ,stop[N];
bool st[N];
int n, m;

int dijkstra()
{
    memset(d, INF, sizeof d);
    d[1] = 0;

    for(int i = 1; i <= n; i++)
    {
        int t = -1;
        for(int j = 1; j <= n; j++)
            if(!st[j] && (t == -1 || d[j] < d[t]))
                t = j;

        st[t] = true;

        for(int j = 1; j <= n; j++)
            d[j] = min(d[j], d[t] + g[t][j]);
    }


    return d[n];    
}

int main()
{
    memset(g, INF, sizeof g);
    cin >> m >> n;

    string line;
    getline(cin, line);
    while (m -- )
    {
        getline(cin, line);
        stringstream ssin(line);
        int cnt = 0, p;
        while (ssin >> p) stop[cnt ++ ] = p;
        for (int j = 0; j < cnt; j ++ )
            for (int k = j + 1; k < cnt; k ++ )
                g[stop[j]][stop[k]] = 1;
    }

    int t = dijkstra();

    if(t == INF)
        cout << "NO";
    else
        cout << max(0, t - 1);

    return 0;
}

牛客周赛 A题

题目理解

这周赛就会一个题。。。
这个题就是奇数项个,第一个是谁谁就多。如何判断第l项是谁?那就直接把他们拆开,因为数据范围比较大,不能进行(l - 1) * k,python的话就好办了
如果是偶数项个:

  • 那么就看所有的序列是不是都是偶数,如果是那么只能输出-1。都是偶数的话就是首项和公差都是偶数即可。
  • 都是奇数就是首项是奇数,公差是偶数
  • 不然就相等

代码实现

#include<iostream>
using namespace std;

typedef long long ll;

ll a, k, q, l, r;

int main()
{
    cin >> a >> k >> q;
    
    while(q -- )
    {
        cin >> l >> r;
        ll t = r - l + 1;
        
        if(t % 2)   // 奇数项
        {
            // 判断第一个是奇还是偶数
            if(a % 2 == 1 && k % 2 == 1 && (l - 1) % 2 == 1)
                cout << -1 << endl;
            else if(a % 2 == 0 && ((l - 1) % 2 == 0 || k % 2 == 0))
                cout << -1 << endl;
            else
                cout << 1 << endl;
        }else{
            if(a % 2 == 1 && k % 2 == 0)
                cout << 1 << endl;
            else if(a % 2 == 0 && k % 2 == 0)
                cout << -1 << endl;
            else
                cout << 0 << endl;
        }
    }
    return 0;
}

标签:道题,return,第二十三,int,res,ll,include,107,Mod
From: https://www.cnblogs.com/wxzcch/p/17723890.html

相关文章

  • P1075 [NOIP2012 普及组] 质因数分解
    算法一根据唯一分解定理,小于\(n\)的最大的能整除\(n\)的整数一定就是答案,可以暴力枚举。时间复杂度\(O(n)\),实际得分\(60\)。算法二发现算法一不能通过的原因是较大的那个质数可能的取值范围太大了。而较小的那个质数一定小于等于\(\sqrtn\),我们枚举它即可。时间复......
  • 《看了受制了》第二十天,7道题,合计97道
    2023年9月19日牛客,ACWING图论!思前想后,这个图论一定要从0到0.1!!!牛客周赛游游的字符串题目理解输出k个you,然后剩下的都是o即可代码实现#include<iostream>#include<algorithm>#include<cstring>#include<vector>#include<queue>#include<map>#definexfirst#def......
  • 前端歌谣的刷题之路-第二十三题-检测复杂数据类型
    前言我是歌谣我有个兄弟巅峰的时候排名c站总榜19叫前端小歌谣曾经我花了三年的时间创作了他现在我要用五年的时间超越他今天又是接近兄弟的一天人生难免坎坷大不了从头再来歌谣的意志是永恒的放弃很容易但是坚持一定很酷本题目源自于牛客网微信公众号前端小歌谣题目请......
  • 前端歌谣的刷题之路-第二十三题-检测复杂数据类型
     前言我是歌谣我有个兄弟巅峰的时候排名c站总榜19叫前端小歌谣曾经我花了三年的时间创作了他现在我要用五年的时间超越他今天又是接近兄弟的一天人生难免坎坷大不了从头再来歌谣的意志是永恒的放弃很容易但是坚持一定很酷本题目源自于牛客网微信公众号前端小歌谣题目......
  • 《看了受制了》第二十天,6道题,合计90道题
    2023年9月18日今天上午写了Atcoder的翻译,以后对于我这种菜鸡来说,多多少少有点用了。前两个题是贪心,第三个是BFS。Acwing908最大不相交区间数量题目理解全部按右端点进行排序然后如果下一个点的左,比我的右端点还大,那么就肯定不在一个区间然后更新目前的右端点即可代码实......
  • Educational Codeforces Round 107
    依然是四题,但是感觉太久没打,好像变得迟钝了。B题大概就是令\[c={10}^k,a=c*3^k,b=c*2^k\]C的话直接暴力维护每种颜色的第一个位置就行,反正只有50个D的话刚开始没什么想法,构造题什么的真的不会啊打表之后发现,对于k,在cost为0的情况下,最多能造出长度为\(k^2+1\)的串,也就是能够......
  • 《看了受制了》第十九天,7道题,合计84道题
    2023年9月17日今天晚上打了牛客的周赛。题目不是很难的题目,哎,最后一题是位运算,不会啊。。。异或和。。今晚还发现了一个up主,同是21级,大二摘金,我大二哎。每次都会感到世界的层次,认识到自己的弱小。。。而且也发现自己的一些观念上的错误。牛客周赛12小美种树题目理解这个题和......
  • 《看了受制了》第十八天,3道题,合计77道题
    2023年9月16日今天因为acwing题简单,第一次正式AKACWING5149简单计算题目理解真的很简单,就是循环代码实现#include<iostream>#include<cstring>#include<algorithm>usingnamespacestd;intmain(){intT;cin>>T;while(T--){int......
  • 《看了受制了》第十七天,4道题,合计74道题
    2023年9月15日小白月赛前三题,PAT一题。这个PAT,我怕是读题都有困难啊。中文都读半天。。。。。ACWIGN1494银行排队题目理解这个题目就是模拟。纯模,数字字符串来回转。代码实现#include<iostream>#include<cstdio>#include<algorithm>#include<vector>#include<queue>us......
  • 《看了受制了》第十六天,6道题,合计70道题
    2023年9月14日题目不难,但是有点恶心。今天写的这个是真受制ACWING1478签到签出题目理解这个就是要把时间都转化成秒,然后排序即可。代码实现#include<iostream>#include<cstring>#include<algorithm>usingnamespacestd;intn;pair<int,int>in[12],out[12];stri......