牛客笔试小题

目录

牛客.小红取数

 牛客.哈夫曼编码​编辑

牛客.字符编码(上一道题的资料)

牛客.最小的完全平方数


牛客.小红取数

01背包问题:在满足总和必须为k的倍数的情况下,选择最大的总和

1.状态表示:

dp[i][j]:表示从前面i个数字中挑选,总和%k等于j时候,最大的和是多少

因为这个同余定理

2.状态转移方程

不选dp[i-1][j];

选择的话就是

dp[i][j]=dp[i-1][j-a[i]%k]+a[i];

但是j-a[i]%k又可能为负数,此时修正就再加上k即可,但是加k,又会面对超的问题

(j-a[i]%k+k)%k

从前面为0的数字,我都没有数字,啥都选不到,那么余数就是0,但是其他是非法的,所以不能让他选择这里面的值进行参考。

这块的调试,做个参考,用的例子就是测试用例。我们可以看到,最开始第一个数字的余数只能有一个数字是4,结果没想到全变成4了,这也就是说,这个用了上面的0处非法值,所以才要初始化。

import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);int n = in.nextInt();int k = in.nextInt();long[]a=new long[n+1];for(int i=1;i<=n;i++){a[i]=in.nextLong();}long[][]dp=new long[n+1][k];//余数只有可能[0-k-1]for(int i=0;i<=n;i++){for(int j=0;j<k;j++){
//一定要初始化一个足够大的数字
//因为我们这个并不知道他会去上一层找哪一个,所以我们需要初始化负无穷,让他不去考虑这些事情dp[i][j]=-0x3f3f3f3f3f3f3f3fL;}}
//前面0个数字里面挑选dp[0][0]=0;for(int i=1;i<=n;i++){for(int j=0;j<k;j++){   dp[i][j]=Math.max(dp[i-1][(int)(j-a[i]%k+k)%k]+a[i],dp[i-1][j]);}}if(dp[n][0]>0){System.out.print(dp[n][0]);}else{System.out.print(-1);}} 
}

 牛客.哈夫曼编码

刚开始压缩存储,找到里面每个字符存的次数,然后根据次数编辑01字符串,但是假如出现用某序列表示某个字符,但是面临的问题就是,序列中有的是可拆分的,比如说

world 可以拆分 w orld ,wo rld 这种等等

输出最后带权路径长度

边构建,一边统计

比如我们会用到下面的一个1,一个2

1+2,还会用到上面着两个三,也就是1+2+3+3即可。小根堆,弹出两个,然后相加,放里面一个。

import java.util.*;// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别int n = in.nextInt();PriorityQueue<Long>q=new PriorityQueue<>();         long sum=0;for(int i=0;i<n;i++){q.add(in.nextLong());}//构建最优二叉树,最后的那一层不去算,因为最后添加的是6while(q.size()>1){long t1=q.poll();long t2=q.poll();q.add(t1+t2);sum+=t1+t2;}System.out.print(sum);}
}

牛客.字符编码(上一道题的资料)

M:2

T:3

-:2

E:2

C:1

H1

A:1

先从小的开始依次连接

问题是一样的

import java.util.*;// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);while(in.hasNext()){int []hash=new int[300];PriorityQueue<Integer>q=new PriorityQueue<>();char[]s=in.next().toCharArray();for(int i=0;i<s.length;i++){
//这道题的哈希表就别-A,啥的了,他的字符不一定都是啥,但是哈希表做到全统计了就好hash[s[i]]++;}for(int i=0;i<300;i++){if(hash[i]!=0){q.add(hash[i]);}}int sum=0;while(q.size()>1){int a=q.poll();int b=q.poll();q.add(a+b);sum+=a+b;}System.out.println(sum);}}
}

牛客.最小的完全平方数

 

很是玄妙的思想,需要好好啃食,最好用两个例子,一测试就明白了

初始化dp[0][0]=0,其余为无效的值。

import java.util.Scanner;// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {public static void main(String[] args) {Scanner in = new Scanner(System.in);// 注意 hasNext 和 hasNextLine 的区别int n = in.nextInt();//从前i个数字中挑选,总和恰好为j时候,最少的跳出来的个数int[][]dp = new int[n][n + 1];for (int j = 0; j <= n; j++) {dp[0][j] = 0x3f3f3f3f;}dp[0][0] = 0;for (int i = 1; i <= Math.sqrt(n); i++) {for (int j = 1; j <= n; j++) {dp[i][j] = dp[i - 1][j];if (j - i * i >= 0) {dp[i][j] = Math.min(dp[i - 1][j], dp[i][j - i * i] + 1);}}}System.out.print(dp[(int)Math.sqrt(n)][n]);}
}

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

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

微服务——远程调用

为什么需要远程调用&#xff1f; 在微服务架构中&#xff0c;每个服务都是独立部署和运行的&#xff0c;它们之间需要相互协作以完成复杂的业务逻辑。因此&#xff0c;远程调用成为微服务之间通信的主要方式。通过远程调用&#xff0c;一个服务可以请求另一个服务执行某些操作或…

数学建模国赛获奖技巧

一、团队分工合作的技巧&#xff08;三角形配合&#xff09; &#xff08;1&#xff09;队长要组织多沟通多交流&#xff1b; &#xff08;2&#xff09;建议定期开组会&#xff0c;互相讲授自己学习的东西&#xff0c;一人学习&#xff0c;三人收获。 二、AI辅助思路解析&am…

Eureka 原理与实践全攻略

一、Eureka 概述 Eureka 在微服务架构中具有举足轻重的地位。它作为服务注册与发现的核心组件&#xff0c;为分布式系统中的服务管理提供了关键支持。 Eureka 的主要功能包括服务注册、服务发现、服务健康监测和自我保护机制。服务注册功能使得服务提供者能够在启动时将自身的…

【Unity】移动端草海解决方案

草海是开放大世界渲染的必不可少的因素&#xff0c;Unity 原生的 Terrain 草海效率较低&#xff0c;而且无法与 RVT 结合起来&#xff0c;无法在移动端上实现。因此我们自己搓出来一套草海系统&#xff0c;使用 C# 多线程辅助运算&#xff0c;并能支持割草、烧草等进阶玩法。草…

系统编程 网络 http协议

http协议------应用层的协议 万维网&#xff1a;http解决万维网之间互联互通 计算机web端网络只能看到文字 1.如何在万维网中表示一个资源&#xff1f; url <协议>&#xff1a;//<主机>&#xff1a;<端口>/<路径> ------------------------------…

2024软件测试面试,别玩这些题目,轻松拿捏百分之95的测试!

1、你会封装自动化测试框架吗&#xff1f; 自动化框架主要的核心框架就是分层PO模式&#xff1a;分别为&#xff1a;基础封装层BasePage&#xff0c;PO页面对象层&#xff0c;TestCase测试用例层。然后再加上日志处理模块&#xff0c;ini配置文件读取模块&#xff0c;unittest…

计算机毕业设计--基于深度学习(PSPNet、空洞卷积Atrous Convolutions)的多类型图像通用分割模型

基于深度学习(PSPNet、空洞卷积Atrous Convolutions)的多类型图像通用分割模型 更多基于深度学习的毕业设计请关注专栏 --- 计算机毕业设计 ✨ 动物图分割&#xff08;使用训练集DIS5K-TR&#xff0c;DIS-TEs&#xff0c;DUTS-TR_TE &#xff09; ✨自然与人类图像分割&#xf…

[CLIP-VIT-L + Qwen] 多模态大模型源码阅读 - MultiModal篇

[CLIP-VIT-L Qwen] 多模态大模型源码阅读 - MultiModal篇 前情提要源码阅读导包逐行讲解 dataclass部分整体含义逐行解读 模型微调整体含义逐行解读 MultiModal类整体含义逐行解读 参考repo:WatchTower-Liu/VLM-learning; url: VLLM-BASE 前情提要 有关多模态大模型架构中的…

搭建智能客服机器人:langgraph实现用户订单管理

大家好&#xff0c;今天我们将创建一个智能客服机器人&#xff0c;它能够记录用户的食物订单到真实数据库中&#xff0c;并允许用户查看他们的订单。这是一个相对高级的Langgraph项目&#xff0c;大家可以先看一下前面介绍的Langgraph的基础课程。 项目概述 我们要构建的系统…

mysqldump + python 定时备份数据库

场景&#xff1a; 需要对mysql进行定时备份&#xff0c;受限于硬盘空间的大小&#xff0c;需要对备份的数据需要定时清理 python代码实现&#xff1a; # -*- coding:UTF-8 -*- """ProjectName : HotelGo2DelonixPmxFileName : fix_missing_ratesDescripti…

《通义千问AI落地—下》:WebSocket详解

一、前言 文本源自 微博客 且已获授权,请尊重版权。 《通义千问AI落地——下篇》如约而至。Websocket在这一类引用中,起到前后端通信的作用。因此,本文将介绍websocket在这类应用场景下的配置、使用、注意事项以及ws连接升级为wss连接等;如下图,本站已经使用了wss连接…

python实用教程(一):安装配置anaconda(Win10)

下一篇&#xff1a;python实用教程&#xff08;二&#xff09;&#xff1a;安装配置Pycharm及使用(Win10)-CSDN博客 1、简介及下载 Anaconda 是一个开源的 Python 和 R 语言的发行版&#xff0c;专为科学计算、数据分析、机器学习和大数据处理而设计。它包含了众多常用的数据…

【Python】列表和元组

文章目录 概念创建列表访问下标通过下标来修改列表元素获取列表长度下标可以写成负数 切片操作省略后边界省略前边界省略前后边界带有步长的切片 遍历列表元素使用 for 循环使用 for 循环访问下标的方式使用 while 循环 新增元素在末尾新增在任意位置新增 查找元素判定元素是否…

Python酷库之旅-第三方库Pandas(096)

目录 一、用法精讲 411、pandas.DataFrame.values属性 411-1、语法 411-2、参数 411-3、功能 411-4、返回值 411-5、说明 411-6、用法 411-6-1、数据准备 411-6-2、代码示例 411-6-3、结果输出 412、pandas.DataFrame.axes属性 412-1、语法 412-2、参数 412-3、…

背包问题【算法 07】

背包问题 背包问题是经典的计算机科学问题之一&#xff0c;涉及到如何在有限资源的约束下&#xff0c;选择最优的物品组合&#xff0c;以最大化收益。这个问题在现实中有广泛的应用&#xff0c;例如资源分配、物流调度和投资组合优化等。本文将详细介绍背包问题的定义、解决方法…

iphone问题笔记

拼音打字显示一些不相干的词 原因&#xff1a;开启了自动改正&#xff0c;傻逼iphone总以为你打错了。 计算器没有退格键&#xff1f; 解决方法&#xff1a;按住数字往右滑是退格。 关机重启必须去设置里&#xff1f; 连按五次锁屏可以选择关机。

如何选择适合自己的开放式耳机?五款实力出众爆款安利!

开放式耳机以其不侵入耳道的设计&#xff0c;为耳朵提供了更轻的负担&#xff0c;同时保护了耳道健康&#xff0c;这与传统的头戴式或入耳式耳机相比&#xff0c;在长时间佩戴时更能减少不适感。市场上的开放式耳机种类繁多&#xff0c;要找到一款真正满意的产品可能有些困难。…

文件—python

一、文件编码 对于同一份文件&#xff0c;人的视角和计算机的视角是不相同的&#xff0c;人看到的是文字&#xff0c;计算机看到的0和1组成的编码。因为计算机只能识别0和1&#xff0c;无法直接识别文字&#xff0c;那我们是如何在电脑上看到文字的呢&#xff1f; 计算机按照一…

【逐行注释】MATLAB下的IMM-EKF代码

IMM-EKF 基于EKF的多模型交互。以CV和CT两个模型进行交互&#xff0c;这里对代码进行逐行注释。 注释较多&#xff0c;个人理解的时候如果有误&#xff0c;欢迎指正。 每一行都有注释&#xff1a; 模型概况 二维平面上的运动模型&#xff0c;由CV和CT构成&#xff0c;基于…

C++:vector篇

前言&#xff1a; 本篇仅介绍vector中常用的函数接口&#xff0c;如果需要详细的请到官网查看。 vector是一种动态数组&#xff0c;能够自动调整大小。与数组类似&#xff0c;vector使用连续内存来存储元素&#xff0c;允许高效访问&#xff0c;但可以动态增加容量。为了应对容…