【百度之星】题目练手

news2024/10/6 4:09:21

BD202301公园

码题集OJ-公园 (matiji.net)

看到之后就想到之前没写出来的一道cf题目,因为不敢打暴力导致没写出来hhh~

首先,这个问题贪心必有反例(贪心两个人尽早相遇)

数据范围40000, 直接暴力枚举两个人在哪个点相遇。因为并不需要知道任意两个点之间的距离,而是只需要知道t到任意一点的距离,f到任意一点的距离和t到任意一点的距离,三次bfs即可。枚举点求最小值即可。

#include<bits/stdc++.h>

using ll=long long;
using ull=unsigned long long;

using ari=std::array<int,2>;
using PII=std::pair<int,int>;

const int N=4e4+10;
const int mode=1e9+7;
const double eps=1e-6;


int te,fe,s;//小度移动消耗值,度度熊移动消耗值,一起移动的消耗减少值
int t,f,n,m;//小度出发点,度度熊出发点,目标节点,总路径数

std::vector<int> g[N];
int dist[3][N];

void bfs(int x,int tag)
{
    memset(dist[tag],0x3f,sizeof dist[tag]);
    std::queue<int> q;
    dist[tag][x]=0;
    q.push(x);

    while(q.size())
    {
        auto t=q.front();
        q.pop();

        for(auto i:g[t])
        {
            if(dist[tag][t]+1<dist[tag][i])
            {
                dist[tag][i]=dist[tag][t]+1;
                q.push(i);
            }
        }
    }
}
void solve()
{
    std::cin>>te>>fe>>s;
    std::cin>>t>>f>>n>>m;

    for(int i=1;i<=m;i++)
    {
        int x,y;
        std::cin>>x>>y;
        g[x].push_back(y);
        g[y].push_back(x);
    }

    bfs(t,0);
    bfs(f,1);
    bfs(n,2);


    ll ans=1e18;
    for(int i=1;i<=n;i++)
    {
        //std::cout<<dist[0][i]<<'\n';
        //这个点作为集合点
        if(dist[0][i]>=1e9||dist[1][i]>=1e9||dist[2][i]>=1e9) continue;
        ll now=dist[0][i]*te+dist[1][i]*fe+dist[2][i]*(te+fe-s);
        ans=std::min(ans,now);
    }
    if(ans>=1e9) std::cout<<"-1\n";
    else std::cout<<ans<<'\n';
}
signed main()
{
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    //std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

BD202305糖果促销

码题集OJ-糖果促销 (matiji.net)

二分即可,似乎有O1做法。

注意要特判p,k。当p为1时,永动机了属于是,check函数会进入死循环,这时无论需要吃几颗买一颗即可,如果一颗都不吃输出0即可。

#include<bits/stdc++.h>

using ll=long long;
using ull=unsigned long long;

using ari=std::array<int,2>;
using PII=std::pair<int,int>;

const int N=4e4+10;
const int mod=1e9+7;
const double eps=1e-6;
int p,k;
bool check(int x)
{
    ll sum=x;
    ll zhi=x;
    while(x/p)
    {
        int cnt=x/p;
        sum+=cnt;

        x%=p;
        x+=cnt;
    }
    return sum>=k;
}
void solve()
{
    std::cin>>p>>k;

    if(p==1)
    {
        if(k==0) std::cout<<"0\n";
        else std::cout<<"1\n";
        return ;
    }
    int l=0,r=1e9,res=-1;
    while(l<=r)
    {
        int mid=l+r>>1;
        if(check(mid)){
            res=mid;
            r=mid-1;
        }else l=mid+1;
    }
    std::cout<<res<<'\n';
}
signed main()
{
    std::ios::sync_with_stdio(false);
    std::cin.tie(0);

    int t=1;
    std::cin>>t;
    while(t--)
    {
        solve();
    }
    return 0;
}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1828442.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

云原生技术实现Devops自动化运维

云原生技术实现Devops自动化运维 随着云计算和DevOps理念的普及&#xff0c;云原生技术在自动化运维中的应用日益广泛。本文将探讨云原生技术如何通过容器化、微服务架构、CI/CD流水线等手段&#xff0c;提升DevOps自动化运维的效率和灵活性&#xff0c;并通过案例分析具体应用…

Linux screen命令使用

文章目录 1. 前言2. screen是什么?3. screen使用场景描述3. screen常用命令4. 小结5. 参考 1. 前言 实际开发中用到的云服务器&#xff0c;如果项目使用的是python&#xff0c;需要利用项目运行一些时间较长的项目程序脚本的话&#xff0c;由于我们通过ssh连接远端服务器&…

【面经总结】Java集合 - Map

Map 概述 Map 架构 HashMap 要点 以 散列(哈希表) 方式存储键值对&#xff0c;访问速度快没有顺序性允许使用空值和空键有两个影响其性能的参数&#xff1a;初始容量和负载因子。 初始容量&#xff1a;哈希表创建时的容量负载因子&#xff1a;其容量自动扩容之前被允许的最大…

2024年【山东省安全员A证】考试资料及山东省安全员A证试题及解析

题库来源&#xff1a;安全生产模拟考试一点通公众号小程序 山东省安全员A证考试资料是安全生产模拟考试一点通总题库中生成的一套山东省安全员A证试题及解析&#xff0c;安全生产模拟考试一点通上山东省安全员A证作业手机同步练习。2024年【山东省安全员A证】考试资料及山东省…

黑马程序员Springboot2简单学习笔记

Session是用于存放用户与web服务器之间的会话&#xff0c;即服务器为客户端开辟的存储空间。 文章&#xff1a;lombok Slf4j注解 Slf4j是用作日志输出的&#xff0c;一般会在项目每个类的开头加入该注解 可以配置静态资源的访问路径 这样访问任何的静态资源 但是每个页面都得…

20. mediasoup服务器的布署与使用

Mediasoup Demo部署 架构服务分析 服务端提供3个服务&#xff1a; 1.www服务&#xff0c;浏览器通过访问服务器目录获取客户端代码&#xff0c;通过V8引擎&#xff0c;启动底层WebRTC 2.nodejs提供websocket服务和http服务&#xff0c;用于信令交互 3.Mediasoup C提供的流媒体…

Ui学习--UITableView

UI学习 UITableView基础UITableView协议UITableView高级协议与单元格总结 UITableView基础 UITableView作为iOS中的一个控件&#xff0c;用于以表格形式展示数据。例如通讯录好友&#xff0c;朋友圈信息等&#xff0c;都是UITableView的实际运用场景。 首先我们先要加入两个协…

ARM32开发--电源管理单元

知不足而奋进 望远山而前行 目录 文章目录 前言 学习目标 学习内容 PMU 电源域 VDD/VDDA域 备份域 1.2V域 省电模式 睡眠模式 深度睡眠模式 待机模式 几种模式总结 WFI和WFE指令 案例需求 模式初始化 源码 总结 前言 在嵌入式系统中&#xff0c;有效的电池管…

使用kettle做的数据同步案例

1 mongo同步数据到mysql中 我想把51万8400的计算出来的八字信息&#xff0c;从mongo同步到mysql&#xff0c;看看在mysql中运行会怎么样。 选择mongodb input&#xff0c;这个是在Big Data中。 填写数据库和表 获取到mongodb的字段,获取到mongo的字段&#xff0c;如果某个字段…

Windows10 利用QT搭建SOEM开发环境

文章目录 一. SOEM库简介二. 安装WinPcap三. SOEM(1.4)库安装(1) 编译32位库(2) 编译64位库 四. 运行SOEM示例代码五. WIN10下利用QT构建SOEM开发环境 一. SOEM库简介 SOEM&#xff08;Scalable Open EtherCAT Master 或 Simple Open EtherCAT Master&#xff09;是一个开源的…

SwiftUI 6.0(iOS 18)新容器视图修改器漫谈

概览 本届 WWDC 2024 观影正如火如荼的进行中&#xff0c;一片鸟语花香、枝繁叶茂的苹果树上不时结出几颗令人垂涎欲滴的美味苹果让秃头码农们欲罢不能。 如您所愿&#xff0c;在界面布局“利器” SwiftUI 这根蔓藤也长出不少喜人的果实&#xff0c;其中在 iOS 18.0 中新添加的…

1949年到2021年中国历年稻谷产量统计报告

数据介绍 数据来源于国家统计局&#xff0c;为1949年到2021年我国每年的稻谷产量数据。 2021年&#xff0c;我国稻谷产量为21284.24万吨&#xff0c;比上年增长0.5%。 数据统计单位为&#xff1a;万吨 我国稻谷产量有多少&#xff1f; 2021年&#xff0c;我国稻谷产量为2128…

TIA Portal 博途西门子自动化编程软件下载安装,TIA Portal 提高生产效率!

驱动编程功能则是TIA Portal的又一亮点&#xff0c;它支持各种驱动器的编程和配置&#xff0c;使设备能够精准地执行各种运动控制任务。此外&#xff0c;SCADA&#xff08;监控与数据采集&#xff09;编程功能使得用户可以实时监控生产过程的各项数据&#xff0c;确保生产过程的…

全网爆火的AI语音合成工具-ChatTTS,有人已经拿它赚到了第一桶金,送增强版整合包

上篇分享了如何从0到1搭建一套语音交互系统。 其中&#xff0c;语音合成&#xff08;TTS&#xff09;是提升用户体验的关键所在。 不得不说&#xff0c;AI 语音界人才辈出&#xff0c;从之前的Bert-Sovit&#xff0c;到GPT-Sovits&#xff0c;再到最近一周狂揽了 1w Star 的C…

在顺序表中使用顺序查找法查找某个关键字

//顺序表中顺序查找(SeqSearch) #include<stdio.h> #include<stdlib.h> #define MAX 100 #include<assert.h> typedef struct {int data[MAX];int length; }SeqList; int SeqSearch(SeqList* S, int key)//key为要查找的值 {printf("关键字序列&#xf…

11.泛型、trait和生命周期(上)

标题 一、泛型数据的引入二、改写为泛型函数三、结构体/枚举中的泛型定义四、方法定义中的泛型 一、泛型数据的引入 下面是两个函数&#xff0c;分别用来取得整型和符号型vector中的最大值 use std::fs::File;fn get_max_float_value_from_vector(src: &[f64]) -> f64…

转让注册地址在北京的无区域投资管理集团公司

公司名称中不带省市地域&#xff0c;或是公司名称没有行业表述的公司&#xff0c;都是要在工商总局进行核名的&#xff0c;我们简称为总局无区域核名公司&#xff0c;此类公司的注册须经总局局批准&#xff0c;名称可以不带省市地域、行业特点&#xff0c;现在公司名称新核准已…

LeetCode206-反转链表

题目 给你单链表的头节点 head &#xff0c;请你反转链表&#xff0c;并返回反转后的链表。 代码 /*** Definition for singly-linked list.* public class ListNode {* int val;* ListNode next;* ListNode() {}* ListNode(int val) { this.val val; }* …

【网络编程】进程间的通信

进程间通信意味着两个不同进程间交换数据&#xff0c;操作系统中应提供两个进程可以同时访问内存空间。 管道实现进程间通信 管道不属于进程资源&#xff0c;与套接字一样属于操作系统。两个进程通过操作系统提供内存空间进行通信 #include<unistd.h> int pipe(int fil…

高考志愿填报,如何选择大学专业?

选择大学专业是一件需要谨慎的事情&#xff0c;需要综合考虑各个因素。大学专业和将来的就业方向是一致的&#xff0c;选专业实际就是在选职业&#xff0c;选自己未来几十年的职业生活。如何去选择大学专业&#xff0c;建议从个人兴趣&#xff0c;个人优势能力&#xff0c;职业…