2024牛客寒假算法基础集训营1

news2024/11/20 1:24:17

文章目录

    • A DFS搜索
    • M牛客老粉才知道的秘密
    • G why外卖
    • E 本题又主要考察了贪心
    • B 关鸡
    • C 按闹分配

今天的牛客,说是都是基础题,头昏昏的,感觉真不会写,只能赛后补题了

A DFS搜索

写的时候刚开始以为还是比较难的,和dfs有关,读完题目发现就是一个序列中含有dfs,而且字符串的长度小于等于五十,可以直接三层暴力搜索即可。

需要注意要考虑长度小于3的情况,刚开始没有考虑到,如果小于3,肯定是不符合的。
AC代码

#include <bits/stdc++.h>
using namespace std;
int main()
{
  int n;
  cin >> n;
  string s1 = "DFS";
  string s2 = "dfs";

  while (n--)
  {
    bool flag1 = false;
    bool flag2 = false;
    int t;
    string s;
    cin >> t >> s;
    if (s.length() < 3)
    {
      cout << "0"
           << " "
           << "0" << endl;
      continue;
    }
    for (int i = 0; i < s.length() - 2; i++)
    {

      if (s[i] == 'D')
      {
        for (int j = i + 1; j < s.length() - 1; j++)
        {
          if (s[j] == 'F')
          {
            for (int k = j + 1; k < s.length(); k++)
            {
              if (s[k] == 'S')
              {
                // 满足条件的
                flag1 = true;
              }
            }
          }
        }
      }
    }

    for (int i = 0; i < s.length() - 2; i++)
    {
      char c = s[i];
      if (s[i] == 'd')
      {
        for (int j = i + 1; j < s.length() - 1; j++)
        {
          if (s[j] == 'f')
          {
            for (int k = j + 1; k < s.length(); k++)
            {
              if (s[k] == 's')
              {
                // 满足条件的
                flag2 = true;
              }
            }
          }
        }
      }
    }
    if (flag1 == true)
    {
      cout << "1"
           << " ";
    }
    else
    {
      cout << "0"
           << " ";
    }
    if (flag2 == true)
    {
      cout << "1" << endl;
    }
    else
    {
      cout << "0" << endl;
    }
  }
}

M牛客老粉才知道的秘密

image.png
这道题目其实可以看做是数论和找规律的题目,属于div4了。

每次只能显示6道题目,刚开始去模拟了一遍,超时间复杂度了,需要的是O(1);

可以这样想着,如果为6的整数,那么最左侧一道的可能性,往后移动应该是n/6,并且向右和向左是相同的位置

如果不是6的整数呢?先移动n/6次,再+一次移动到了最右边。此时为n/6+1;
从最右边往左开始移动,可以发现,最左边的位置和向右移动只可能在1的时候会有重复,其他是不可能重复的,因为刚才发生移位了。
所以数量为n/6-1 。综上就是n/6*2;

AC代码


import java.util.Scanner;

public class Main {
    public static void main(String[] args) {
        Scanner scanner=new Scanner(System.in);
        int t=scanner.nextInt();
        while (t-->0){
            int sum=0;
            int n=scanner.nextInt();
            int k=n%6;
            if (k!=0){
                //简单的逻辑思维题目
                int m=n/6;
                sum+=m+m;
            }else{
                sum+=n/6;
            }
            System.out.println(sum);
        }
    }
}

G why外卖

这也是一道模拟题目,感觉是基本的高中数学题目,要想明白他们之间的关系,我感觉就可以了
image.png
可以使用优惠卷,但是购买物品的价格必须大于所用的优惠卷,我刚开始在想如果花费价格小于优惠卷如何解决?
其实这个问题是可以不同解决的。
image.png
sum是可以减去的钱,sum+m可以你可以购买最大商品的价值,如果sum+m大于了当前的优惠卷,就可以ans就等于n+sum;
但是如果现在是100 80 只有10块钱,那么不符合要求,为什么sum还要加上八十呢?
这个80现在其实只是加在了sum里面,并没有加到ans里面。因为数组是升序的,也就是后面如果大于了,说明前面一定也是大于的。就可以加进来。

package 牛客寒假训练营.第一场.G;

import java.util.Arrays;
import java.util.Scanner;

class Money implements Comparable<Money> {
    long a;
long b;

public Money(long a, long b) {
    this.a = a;
    this.b = b;
}

@Override
public int compareTo(Money other) {
    return Long.compare(this.a, other.a);
}
}

public class Main {
public static void main(String[] args) {
    Scanner scanner = new Scanner(System.in);

    int t = scanner.nextInt();
    while (t-- > 0) {
        solve(scanner);
    }
}

static void solve(Scanner scanner) {
    int n = scanner.nextInt();
    long m = scanner.nextLong();
    Money[] c = new Money[100005];
    long ans = m;
    long sum = 0;

    for (int i = 1; i <= n; i++) {
        long a = scanner.nextLong();
        long b = scanner.nextLong();
        c[i] = new Money(a, b);
    }

    Arrays.sort(c, 1, n + 1); //排序,出来的按照优惠的价格进行排序

    for (int i = 1; i <= n; i++) {
        sum += c[i].b;//优惠的价格
        if (sum + m >= c[i].a) {
            ans = m + sum;
        }
    }
    System.out.println(ans);
}
}

E 本题又主要考察了贪心

不能被题目的名称所迷惑,说是贪心考点,其实并不是贪心。

这道题在考场如何去做呢?先看数据范围。
image.png
每次比赛都有三种对应的可能,m<=10,说明最多有十场比赛,也就是3的10次方,这个时间复杂度是可以接收的,可以想到用dfs去解决。

#include <bits/stdc++.h>
using namespace std;
int n, m;
int x[101], y[101];
int ans, a[101];

// u是对应的场数 当u>m表示比赛已经结束的时候
void dfs(int u)
{
    if (u > m)
    {
        int rank = 1;
        for (int i = 2; i <= n; i++)
            {
                if (a[1] < a[i])
                    rank++;
            }
        ans = min(ans, rank);
        return;
    }
    a[x[u]] += 3;
    dfs(u + 1);
    a[x[u]] -= 3;

    a[y[u]] += 3;
    dfs(u + 1);
    a[y[u]] -= 3;

    a[x[u]]++;
    a[y[u]]++;
    dfs(u + 1);
    a[x[u]]--;
    a[y[u]]--;
}
int main()
{
    int t;
    cin >> t;
    while (t--)
        {
            cin >> n >> m;
            ans = n;
            for (int i = 1; i <= n; i++)
                {
                    cin >> a[i];
                }
            for (int i = 1; i <= m; i++)
                {
                    cin >> x[i] >> y[i];
                }
            dfs(1);
            cout << ans << endl;
        }
}

其实就是可以看作为一个三叉树来看,每一次都是有A赢或者B赢或者AB平局,走遍每一个路径,需要找到最好的排名。时间复杂度 o(n*3^m);
用a数组来存左边操作的玩家,用b数组来存储右边操作的玩家。
dfs结束的条件,就是u>m表示游戏轮数结束了

B 关鸡

如何将这个鸡关在里面呢?
image.png
想要这个鸡不跑出去有两个情况,第一个是需要四个点,各方在两边即可。第二个是三个火点直接将g包围即可。
所以刚开始让ans1=4,ans2=3 看两个哪个小,ans2需要全部包围只能由一种情况,就是刚开始是包围的。并且如果n==0,一定是最小需要三个,直接包围起来。

#include <bits/stdc++.h>
#define int long long
#define pii pair<double,double>
using namespace std;
const int N=2e5+5;
int t,n,m,k;
int x,y,a[N],b[N];
signed main() {
    cin>>t; // 输入测试用例数量
    while(t--) {
        cin>>n; // 输入点的数量
        if(n==0) { // 如果点的数量为0
            cout<<3<<endl; // 输出3
            continue;
        }
        map<int,int> ma1,ma2; // 定义两个map,用于统计x=1和x=2的y的出现次数
        int ans1=4,ans2=3; // 初始化两个答案,分别对应x=1和x=2的情况
        bool ll=0,rr=0; // 判断左右区间是否有点
        for(int i=0;i<n;i++) {
            cin>>x>>y; // 输入x和y
            if(x==1&&y==1) ans2--; // 如果x=1,y=1,ans2减1
            if(x==1&&y==-1) ans2--; // 如果x=1,y=-1,ans2减1
            if(x==2&&y==0) ans2--; // 如果x=2,y=0,ans2减1

            if(y<=0) ll=1; // 如果y<=0,左区间有点
            if(y>=0) rr=1; // 如果y>=0,右区间有点
            if(x==1) {
                ma1[y]++; // 统计x=1的y出现的次数
            }
            if(x==2) {
                ma2[y]++; // 统计x=2的y出现的次数
            }
        }
        if(ll) ans1--; // 如果左区间有点,ans1减1   左边有端点
        if(rr) ans1--; // 如果右区间有点,ans1减1   右边有端点

        bool l=0,r=0; // 判断左右区间是否有点
        for(auto it:ma1) {
            int p=it.first; // 获取y的值
            if(p<0) {
                //存在一个点周围有其他点,那边这里肯定是出不去的 下面ans还需要--;
                if(ma2[p-1]||ma2[p]||ma2[p+1]) l=1; // 如果左区间存在点,l置为1
            }
            if(p>0) {
                if(ma2[p-1]||ma2[p]||ma2[p+1]) r=1; // 如果右区间存在点,r置为1
            }
        }
        if(l) ans1--; // 如果左区间有点,ans1减1
        if(r) ans1--; // 如果右区间有点,ans1减1
        cout<<min(ans1,ans2)<<endl; // 输出两个答案中的较小值
    }
    return 0;
}
//3 2 1 5 4
//3 4 5 1 2
/*
  abcabcabc
  
 */  

这里用到了map来存储对应的地图值,暴力遍历的。

C 按闹分配


##image.png
image.png
image.png
增加的不满意度就是 tc*排在鸡后面的人数,给定了最大不满意度,所以可以算出来最多人数为m/tc。向下进行取整
此时再将排在鸡前面的时间加起来再加上鸡需要的时间,就是最早的时间了。
AC代码

#include<bits/stdc++.h>

#define int long long
#define IOS ios::sync_with_stdio(false),cin.tie(0),cout.tie(0)

using namespace std;

const int N = 1e5+10;

int t[N],s[N];
int tt[N],ss[N];

signed main(){
	IOS;
	int n,q,tc;
    cin >> n >> q >> tc;
    for(int i=1;i<=n;i++){
        cin >> t[i];
    }
    sort(t+1,t+1+n);
    for(int i=1;i<=q;i++){
        int m;
        cin >> m;
        int ans=0;
        int w=m/tc;
        for(int i=1;i<=n-w;i++) ans+=t[i];
        cout << ans+tc << '\n';
    }
	return 0;
}

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

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

相关文章

【甲方安全建设】DevOps初体验

文章目录 前言传统的开发方式&#xff1a;Docker-解决环境问题 DevOps-CI/CD走向流水线Jenkins工作流程Git拉取代码Maven构建打包通过SSH连接后端服务器 实现效果 DevSecOps-安全赋能关于安全平台漏洞扫描漏洞预警TODO 前言 临近春节&#xff0c;笔者经过半年北漂&#xff0c;…

【GitHub项目推荐--一个由OpenAI提供支持的聊天机器人和虚拟助手的构建平台】【转载】

Botpress Botpress是一个开源项目&#xff0c;它提供了一个平台&#xff0c;用于构建、部署和管理基于人工智能的聊天机器人和虚拟助手 github地址&#xff1a; https://github.com/botpress/botpress Botpress的介绍 Botpress是一个开源项目&#xff0c;它提供了一个平台&…

【PaddleSpeech】语音合成-男声

环境安装 系统&#xff1a;Ubuntu > 16.04 源码下载 使用apt安装 build-essential sudo apt install build-essential 克隆 PaddleSpeech 仓库 # github下载 git clone https://github.com/PaddlePaddle/PaddleSpeech.git # 也可以从gitee下载 git clone https://gite…

音视频数字化(音乐CD)

上篇文章【音视频数字化(音频数字化)】我们聊了音频数字化原理,其中谈到了音乐CD,结尾也提到了一个小问题:“CD音质是最高吗?为什么?”不知道大家是怎么理解的。 其实CD质量只是“无损”存储,但是数字化标准只是“44.1kHz,16bit”,因此相对于现在,音质不能说最高。 …

day03.函数与指针(含new与delete关键字)

一.指针 #include<iostream> using namespace std; #define pi 3.14159//定义常量int main(){cout<<pi<<endl;int a10;int *pNULL;//定义指针p&a;cout<<"a的地址为&#xff1a;"<<p<<endl;cout<<"a"<&l…

【面试深度解析】快手后端一面:G1、IOC、AOP、并发、JVM生产问题定位、可重复读、ThreadLocal

欢迎关注公众号&#xff08;通过文章导读关注&#xff1a;【11来了】&#xff09;&#xff0c;及时收到 AI 前沿项目工具及新技术的推送&#xff01; 在我后台回复 「资料」 可领取编程高频电子书&#xff01; 在我后台回复「面试」可领取硬核面试笔记&#xff01; 文章导读地址…

C# 引用同一个dll不同版本的程序集

因为项目需要所以必须在项目中引用不同版本的同一程序集 我要引用的文件是newtonsoft.json.dll 两个版本为12.0.0.0 和4.0.0.0 1.如果已经先引入了newtonsoft.json 12.0.0.0版本的程序集&#xff0c;如果直接引入另一个版本的程序集的话会提示不成功&#xff0c;所以先将另一个…

C++学习Day01之双冒号作用域运算符

目录 一、程序二、输出三、分析与总结 一、程序 #include<iostream>int atk 1000; void test01() {int atk 2000;std::cout << "atk " << atk << std::endl;// ::代表作用域 如果前面什么都不添加 代表全局作用域std::cout << &q…

c++阶梯之auto关键字与范围for

auto关键字&#xff08;c11&#xff09; 1. auto关键字的诞生背景 随着程序的逐渐复杂&#xff0c;程序代码中用到的类型也越来越复杂。譬如&#xff1a; 类型难以拼写&#xff1b;含义不明确容易出错。 比如下面一段代码&#xff1a; #include <string> #include &…

Sketch使用手册:从入门到精通的完整教程

Sketch软件是Mac平台上流行的矢量图形编辑软件&#xff0c;旨在帮助用户创建网站、移动应用、图标等各种设计原型。Sketch软件的设计风格简洁明了&#xff0c;界面操作简单易用&#xff0c;非常适合UI/UX设计师、平面设计师等数字创意人员。本文将根据如何使用Sketch&#xff0…

嵌入式中C 语言中的三块技术难点

C 语言在嵌入式学习中是必备的知识&#xff0c;甚至大部分操作系统都要围绕 C 语言进行&#xff0c;而其中有三块技术难点&#xff0c;几乎是公认级别的“难啃的硬骨头”。 今天就来带你将这三块硬骨头细细拆解开来&#xff0c;一定让你看明白了。 0x01 指针 指针是公认最难理…

10. BI - 决策树的使用及可视化

本文为 「茶桁的 AI 秘籍 - BI 篇 第 10 篇」 文章目录 可视化探索决策树原理决策树算法决策树可视化泰坦尼克海难数据 Hi&#xff0c;你好。我是茶桁。 上一节课&#xff0c;咱们了解了图形的具体绘制方法&#xff0c;接下来咱们还要看看除了图形绘制之外&#xff0c;还有哪些…

Redis进阶(一):持久化

持久化 何为持久化&#xff1f; MySQL的事务有四个比较核心的特征&#xff1a;原子性、一致性、持久性和隔离性&#xff0c;这里的持久性和持久化说的是一个事&#xff0c;简单来说&#xff0c;数据存储在硬盘上就是持久&#xff0c;存在内存上那就是不持久&#xff08;重启之后…

PyTorch基础-Tensors属性、Tensor的运算

PyTorch的基本概念 Tensor的基本概念 张量高于标量、向量、矩阵 标量说零维的张量&#xff0c;向量是一维的张量&#xff0c;矩阵是二维的张量 Tensor与机器学习的关系 Tensor的创建 函数功能Tensor(*size)基础构造函数Tensor(data)类似np.arrayones(*size)全1Tensorzeros(…

举个栗子!Tableau 技巧(263):按需突出显示文本表的 N 个行

我们分享过 &#x1f330; &#xff1a;突出显示文本表的行或列&#xff0c;可以突出显示文本表中的某一行或某一列。有数据粉提出新的问题&#xff1a;如果想突出显示多行数据&#xff0c;该如何实现呢&#xff1f; 在 Tableau 中是可以实现的&#xff08;如上图&#xff09;&…

代码随想录刷题第23天

今天是二叉树的终章&#xff0c;不知不觉已经刷题23天了&#xff0c;先给自己点个赞&#x1f604;&#x1f44d; 第一题是修剪二叉搜索树&#xff0c;要注意修剪时被删除节点的子树可能符合要求&#xff0c;因此还需向下遍历。最后用root->left与right接住返回值。 迭代法先…

PHP漏洞查询

CVE - Search CVE List (mitre.org) 美国国家漏洞数据库&#xff08;需要梯子&#xff09; NATIONAL VULNERABILITY DATABASE NVD - Search and Statistics (nist.gov) 基本都能查询到&#xff0c;传结果详情页里面会有一些解决方案的连接 PHP的官方网站 PHP :: Bugs :: Se…

大模型实践笔记(1)——GLM-6B实践

目录 在Ubuntu上的配置Git Large File Storage 安装Git LFS&#xff1a; 设置Git LFS&#xff1a; 使用Git LFS&#xff1a; 安装GLM-6B 环境依赖 ChatGLM2-6B介绍 配置GLM 下载代码 构建环境 安装依赖 本地部署 网页UI 很多模型在hugging face上面&#xff0c;…

【Linux】 Linux编译器-gcc/g++使用

&#x1f497;个人主页&#x1f497; ⭐个人专栏——Linux学习⭐ &#x1f4ab;点击关注&#x1f929;一起学习C语言&#x1f4af;&#x1f4ab; 目录 导读1. Linux编译器-gcc/g使用1.1 引入1.2 初识gcc/g1.3 程序运行的四个阶段1.3.1 预处理1.3.2 编译1.3.3 汇编1.3.4 链接 1.…

【Python】一个简单的小案例:实现批量修改图片格式

1.代码 import os from tkinter import Tk, Button from PIL import Imagedef check_and_create_folders():# 获取当前目录current_directory os.getcwd()# 定义文件夹名称folders_to_check ["JPG", "PNG"]for folder_name in folders_to_check:folder_…