牛客笔试,牛客.四个选项(dfs巨难)牛客.接雨水动态规划单调栈解法牛客.栈和排序牛客.加减

本文主要是介绍牛客笔试,牛客.四个选项(dfs巨难)牛客.接雨水动态规划单调栈解法牛客.栈和排序牛客.加减,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

目录

牛客.四个选项(dfs巨难)

牛客.接雨水

动态规划

单调栈解法

牛客.栈和排序

牛客.加减


牛客.四个选项(dfs巨难)

 

刚开始我是想着用数学,Cxx去解决,但是他的还有其余条件,就没有办法解决,所以就枚举 ,递归的数据量不大时候,是推荐使用的

import java.util.*;// 注意类名必须为 Main, 不要有任何 package xxx 信息
public class Main {static int []a;static int[]path=new int[13];//记录当前路径填写了哪些选项static int sum;static boolean[][]same=new boolean[13][13];public static void  dfs(int pos){if(pos>12){
//12个填写满是1种,我们需要写完12种sum++;return ;}for(int i=1;i<=4;i++){if(a[i]==0){//剪枝,看看有没有剩余的次数
continue;}if(!isSame(pos,i))continue; //判断是否需要相同的题目,填写了相同的选项//在pos位置填写了i选项,当我们path[pos]如果我们下次循环,会覆盖掉这次的经历。path[pos]=i;a[i]--;dfs(pos+1);a[i]++;}} //pos位置,填写cur的时候static boolean isSame(int pos,int cur){for(int i=1;i<pos;i++){//pos和i必须要是相同的,path和cur要填的不同是不合法的if(same[pos][i]==true&&path[i]!=cur){return false;}}//当前位置填写cur合法return true;}public static void main(String[] args) {Scanner in = new Scanner(System.in);a=new int[6];for(int i=1;i<=5;i++){a[i]=in.nextInt();}while(a[5]!=0){int x=in.nextInt();int y=in.nextInt();same[x][y]=same[y][x]=true;a[5]--;}dfs(1); System.out.println(sum);}
}

牛客.接雨水

动态规划

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** max water* @param arr int整型一维数组 the array* @return long长整型*/public long maxWater (int[] arr) {int n=arr.length;long sum=0;int[]left=new int[n];int[]right=new int[n];left[0]=arr[0];//0-ifor(int i=1;i<n;i++){left[i]=Math.max(left[i-1],arr[i]);}//预处理右侧 i到 nright[n-1]=arr[n-1];for(int i=n-2;i>=0;i--){//后面位置的最大值,和当前位置的最大值right[i]=Math.max(right[i+1],arr[i]);}for(int i=1;i<n-1;i++){sum+=Math.min(left[i],right[i])-arr[i];}return sum;}
}

单调栈解法

class Solution {public int trap(int[] height) {Stack<Integer> stack = new Stack<>();int res = 0;// 遍历每个柱体for (int i = 0; i < height.length; i++) {while (!stack.isEmpty() && height[stack.peek()] < height[i]) {int mid = stack.pop();// 如果栈顶元素一直相等,那么全都pop出去,只留第一个。while (!stack.isEmpty() && height[stack.peek()] == height[mid]) {stack.pop();}if (!stack.isEmpty()) {// stack.peek()是此次接住的雨水的左边界的位置,右边界是当前的柱体,即i。// Math.min(height[stack.peek()], height[i]) 是左右柱子高度的min,减去height[mid]就是雨水的高度。// i - stack.peek() - 1 是雨水的宽度。res += (Math.min(height[stack.peek()], height[i]) - height[mid]) * (i - stack.peek() - 1);}}stack.push(i);}return res;}
}

牛客.栈和排序

好想不好写,蛮考验代码功力的

然后有一些,还在栈里面,就等栈空不空,接着搞

import java.util.*;public class Solution {/*** 代码中的类名、方法名、参数名已经指定,请勿修改,直接返回方法规定的值即可** 栈排序* @param a int整型一维数组 描述入栈顺序* @return int整型一维数组*/public int[] solve (int[] a) {int n = a.length;Stack<Integer>stack = new Stack<>();ArrayList<Integer>ret = new  ArrayList<>();int count = n;int []hash = new int[n + 1];for (int i = 0; i < n; i++) {stack.add(a[i]);hash[a[i]]++;if (a[i] == count && (stack.isEmpty() || stack.peek() < a[i])) {stack.pop();ret.add(a[i]);hash[count]++;count--;}while (hash[count] != 0) {count--;}while (!stack.isEmpty() && stack.peek() > count) {ret.add(stack.pop());}}while (!stack.isEmpty()) {ret.add(stack.pop());}int []p = new int[n];for (int i = 0; i < n; i++) {p[i] = ret.get(i);}return p;}}

牛客.加减

如何求一个区间的最小代价

加入选择a2与a3比较

a3的花费是 整段+a2——a4

a2的花费是 整段+a2——a4+a3-a2所以最中间的点有优势

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();long k = in.nextLong();long []a = new long[n+1];long []sum = new long[n+1];int count=0;for (int i = 1; i <= n; i++) {a[i] = in.nextLong();}Arrays.sort(a);for (int i = 1; i <= n; i++) {sum[i]=sum[i-1]+a[i];}long cost=0;int left = 1;int right = 1; while(right<=n){      int mid=(left+right)/2;    cost=(mid-left)*a[mid]-(sum[mid-1]-sum[left-1])+(sum[right]-sum[mid])-(right-mid)*a[mid];     while(cost>k){left++;mid=(left+right)/2; cost=(mid-left)*a[mid]-(sum[mid-1]-sum[left-1])+(sum[right]-sum[mid])-(right-mid)*a[mid];     }count=Math.max(count,right-left+1);right++;}System.out.print(count);}}

这篇关于牛客笔试,牛客.四个选项(dfs巨难)牛客.接雨水动态规划单调栈解法牛客.栈和排序牛客.加减的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/1135967

相关文章

Java调用C#动态库的三种方法详解

《Java调用C#动态库的三种方法详解》在这个多语言编程的时代,Java和C#就像两位才华横溢的舞者,各自在不同的舞台上展现着独特的魅力,然而,当它们携手合作时,又会碰撞出怎样绚丽的火花呢?今天,我们... 目录方法1:C++/CLI搭建桥梁——Java ↔ C# 的“翻译官”步骤1:创建C#类库(.NET

MyBatis编写嵌套子查询的动态SQL实践详解

《MyBatis编写嵌套子查询的动态SQL实践详解》在Java生态中,MyBatis作为一款优秀的ORM框架,广泛应用于数据库操作,本文将深入探讨如何在MyBatis中编写嵌套子查询的动态SQL,并结... 目录一、Myhttp://www.chinasem.cnBATis动态SQL的核心优势1. 灵活性与可

Mybatis嵌套子查询动态SQL编写实践

《Mybatis嵌套子查询动态SQL编写实践》:本文主要介绍Mybatis嵌套子查询动态SQL编写方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录前言一、实体类1、主类2、子类二、Mapper三、XML四、详解总结前言MyBATis的xml文件编写动态SQL

SpringBoot实现Kafka动态反序列化的完整代码

《SpringBoot实现Kafka动态反序列化的完整代码》在分布式系统中,Kafka作为高吞吐量的消息队列,常常需要处理来自不同主题(Topic)的异构数据,不同的业务场景可能要求对同一消费者组内的... 目录引言一、问题背景1.1 动态反序列化的需求1.2 常见问题二、动态反序列化的核心方案2.1 ht

golang实现动态路由的项目实践

《golang实现动态路由的项目实践》本文主要介绍了golang实现动态路由项目实践,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习... 目录一、动态路由1.结构体(数据库的定义)2.预加载preload3.添加关联的方法一、动态路由1

Java List排序实例代码详解

《JavaList排序实例代码详解》:本文主要介绍JavaList排序的相关资料,Java排序方法包括自然排序、自定义排序、Lambda简化及多条件排序,实现灵活且代码简洁,文中通过代码介绍的... 目录一、自然排序二、自定义排序规则三、使用 Lambda 表达式简化 Comparator四、多条件排序五、

JAVA数组中五种常见排序方法整理汇总

《JAVA数组中五种常见排序方法整理汇总》本文给大家分享五种常用的Java数组排序方法整理,每种方法结合示例代码给大家介绍的非常详细,感兴趣的朋友跟随小编一起看看吧... 目录前言:法一:Arrays.sort()法二:冒泡排序法三:选择排序法四:反转排序法五:直接插入排序前言:几种常用的Java数组排序

Python Selenium动态渲染页面和抓取的使用指南

《PythonSelenium动态渲染页面和抓取的使用指南》在Web数据采集领域,动态渲染页面已成为现代网站的主流形式,本文将从技术原理,环境配置,核心功能系统讲解Selenium在Python动态... 目录一、Selenium技术架构解析二、环境搭建与基础配置1. 组件安装2. 驱动配置3. 基础操作模

慢sql提前分析预警和动态sql替换-Mybatis-SQL

《慢sql提前分析预警和动态sql替换-Mybatis-SQL》为防止慢SQL问题而开发的MyBatis组件,该组件能够在开发、测试阶段自动分析SQL语句,并在出现慢SQL问题时通过Ducc配置实现动... 目录背景解决思路开源方案调研设计方案详细设计使用方法1、引入依赖jar包2、配置组件XML3、核心配

springboot使用Scheduling实现动态增删启停定时任务教程

《springboot使用Scheduling实现动态增删启停定时任务教程》:本文主要介绍springboot使用Scheduling实现动态增删启停定时任务教程,具有很好的参考价值,希望对大家有... 目录1、配置定时任务需要的线程池2、创建ScheduledFuture的包装类3、注册定时任务,增加、删