1.华为实习笔试

article/2025/10/11 8:52:21

第一题(100分)

版本号排序问题,比如1.1.1版本大于1.0.0版本,每个.分割的数字范围是0-256,可以省略,比如..等价于0.0.0,可以有前导0,比如001.001.1等价于1.1.1;程序输入:需要排序的版本号个数,和各个版本号字符串,输出排序后的结果

public static List<String> dealSplit(String str){int firstIndex=str.indexOf('.');int lastIndex=str.lastIndexOf('.');List<String> list = new ArrayList<>(3);if(firstIndex==0)list.add("0");else list.add(str.substring(0,firstIndex));if(firstIndex+1==lastIndex)list.add("0");else list.add(str.substring(firstIndex+1,lastIndex));if(lastIndex==str.length()-1)list.add("0");else list.add(str.substring(lastIndex+1));return list;}public static int compare(List<String> list){int res=0;int mul=257*257;for (int i = 0; i < list.size(); i++) {String s = list.get(i);int index=0;while (index<s.length()&&s.charAt(index)=='0'){index++;}if(index!=s.length()) {res+=Integer.parseInt(s.substring(index))*mul;}mul/=257;}return res;}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while (scanner.hasNext()){int num=scanner.nextInt();PriorityQueue<String> queue = new PriorityQueue<String>((a,b)->{return  compare( dealSplit(b))-compare( dealSplit(a));});for (int i = 0; i < num; i++) {String s=scanner.next();queue.add(s);}while (!queue.isEmpty()){System.out.println(queue.poll());}}}

测试输出:

复盘:正则表达式在对字符串进行分割的时候并不总是分割空字符串,比如如下情况

public static void main(String[] args) {String s="..1";String s2="1..";String s3=".1.";System.out.println(Arrays.toString(s.split("\\.")));System.out.println(Arrays.toString(s2.split("\\.")));System.out.println(Arrays.toString(s3.split("\\.")));}

分割结果可以说是相当迷幻了...

[, , 1]
[1]
[, 1]

第二题(200分)

高峰用餐问题,每个进饭店用餐的人有用餐时间数组[start,end),根据数组输出最高峰的用餐时间段

输入用餐人数和每个用餐时间数组

最朴素的思路是使用一个大数组,作为一条直线段,存储每一个时间段,在[start,end)的位置+1,进一步可以优化数组的大小为(max-min+1),再进一步可以使用差分数组优化+1操作,时间复杂度变为O(1)

public class Main {public static void main(String[] args) {Scanner scanner = new Scanner(System.in);while (scanner.hasNext()){int num=scanner.nextInt();int min=Integer.MAX_VALUE;int max=Integer.MIN_VALUE;int[][] matrix = new int[num][2];for (int i = 0; i < num; i++) {int start=scanner.nextInt();int end=scanner.nextInt();matrix[i][0]=start;matrix[i][1]=end;min=Math.min(start,min);max=Math.max(max,end);}//因为区间是[start,end),长度为max-min,使用差分数组,要多一个位置int[] record = new int[max - min + 1];for (int i = 0; i < matrix.length; i++) {int start=matrix[i][0]-min;int end=matrix[i][1]-min;record[start]+=1;record[end]-=1;}int maxSum=Integer.MIN_VALUE;int sum=0;for (int i = 0; i < record.length; i++) {sum+=record[i];maxSum=Math.max(sum,maxSum);}//最后呈现的数据段可能为多段boolean isStart=true;boolean isContinue=false;sum=0;ArrayList<Integer> list = new ArrayList<>();for (int i = 0; i < record.length; i++) {sum+=record[i];if(isStart&&sum==maxSum){isStart=false;isContinue=true;list.add(i);}if(isContinue&&sum!=maxSum){isContinue=false;isStart=true;list.add(i-1);}}for (Integer integer : list) {System.out.println(integer+min);}}}
}

测试输出:

 第三题(300分)

二维数组中的连连看,数组中的0代表可以经过的区域,其他数字都代表不可经过的方块,给一个输入数组和两个点的坐标(i,j),返回将两个目标点连在一起最少需要的折线数量,下图的情况是三次,路径用绿线表示,红点为两个目标点

1 2 0 0 1 3

1 4 5 0 2 0

static int targetI;static int targetJ;static int initI;static int initJ;static int m;static int n;static int[][] direction = new int[][]{{0, 1}, {0, -1}, {1, 0}, {-1, 0}};static List<Integer> res = new ArrayList<>();static boolean[][] visited;//最后一个变量标识上一次是横向走还是纵向走public static void dfs(int[][] matrix, int i, int j, Boolean row, int num) {if (i == targetI && j == targetJ) {res.add(num);return;}//说明可以访问if (matrix[i][j] == 0||(i==initI&&j==initJ)) {visited[i][j] = true;for (int k = 0; k < 4; k++) {int x = i + direction[k][0];int y = j + direction[k][1];if((x>=0&&y>=0&&x<m&&y<n)&&!visited[x][y]){if (k == 0 || k == 1) {//纵向走if(row==null){dfs(matrix,x,y,false,num+1);}else if(row){//上次横向这次纵向dfs(matrix,x,y,false,num+1);}else{dfs(matrix,x,y,false,num);}}else{//横向走if(row==null){dfs(matrix,x,y,true,num+1);}else if(row){dfs(matrix,x,y,true,num);}else{//上次纵向这次横向dfs(matrix,x,y,true,num+1);}}}}visited[i][j]=false;}}public static void main(String[] args) {Scanner scanner = new Scanner(System.in);m = scanner.nextInt();n = scanner.nextInt();visited = new boolean[m][n];int[][] matrix = new int[m][n];for (int i = 0; i < m; i++) {for (int j = 0; j < n; j++) {matrix[i][j] = scanner.nextInt();}}int i1 = scanner.nextInt();int j1 = scanner.nextInt();int i2 = scanner.nextInt();int j2 = scanner.nextInt();targetI = i2;targetJ = j2;initI=i1;initJ=j1;dfs(matrix,i1,j1,null,0);int min=Integer.MAX_VALUE;for (int i = 0; i < res.size(); i++) {min=Math.min(min,res.get(i));System.out.println("累计折线数"+res.get(i));}System.out.println(min);}

测试输出:


http://chatgpt.dhexx.cn/article/VRi0QqBZ.shtml

相关文章

find命令用法

一.简介 linux的find命令用于查找指定目录中符合参数条件的文件&#xff0c;如果不设置任何参数&#xff0c;则find命令将在当前路径下查找子目录与文件。并且将查到的子目录和文件全部显示。 二.find命令常用参数 1&#xff09;根据文件名及文件拥有人拥有组查找文件 环境…

Linux下find命令详解

Linux下find命令详解 find命令格式find命令的参数find的常规用法1、按名字查找2、按目录查找3、按权限查找4、按类型查找  &#xff08;b/d/c/p/l/f &#xff09;5、按属主及属组6、按时间查找7、按文件新旧8、按大小查找9、执行命令关于 有没有 -print 的区别 find命令格式 …

java find()_java 之 find 命令

转自&#xff1a;https://blog.csdn.net/holyshit666/article/details/52296966 find命令是比较常用的命令&#xff0c;用来在特定目录下查找具有某种特征的文件。 一&#xff1a;find命令格式如下&#xff1a; find [-path......] -options [-print -exec -ok] path:要查找的目…

find 命令常用用法

find 命令——文件或目录查找而且可以直接对查找结果使用命令。 find 查找范围 查找条件 -name 按名称查找 -maxdepth 查看多深的文件&#xff0c;不能超过所限制的目录下的内容 -mindepth 查看不小于多深的文件&#xff0c;不低于所限制内容…

文件查找find命令

#!/bin/bash find /etc -name *.conf find /etc -iname "aa" #不区分大小写 find . -user hdfs find . -group yarn find /etc -type f #文件 find /etc -type d #路径 find /etc -size 1M #文件大小大于1M find /etc -size -100k #文件大小小…

Linux find命令详解

基础打印操作 find命令默认接的命令是-print&#xff0c;它默认以\n将找到的文件分隔。可以使用-print0来使用\0分隔&#xff0c;这样就不会分行了。但是一定要注意&#xff0c;-print0针对的是\n转\0&#xff0c;如果查找的文件名本身就含有空格&#xff0c;则find后-print0仍…

Linux 的find命令用法

摘要 find 是Unix/Linux命令行工具箱中最棒的工具之一。该命令在命令行和shell脚本编写方面都 能发挥功效。find 包含大量特性&#xff0c;本文记录find 的一些常用的查找功能。 find 命令的工作方式如下&#xff1a;沿着文件层次结构向下遍历&#xff0c;匹配符合条件的文件&…

linux find命令格式及find命令详解

本文详细介绍了linux find命令格式及find命令案例&#xff0c;希望对您的学习有所帮助。1、find命令的一般形式为&#xff1b; find pathname -options [-print -exec -ok ...]2、find命令的参数&#xff1b; pathname: find命令所查找的目录路径。例如用.来表示当前目录&#…

Windows命令之find命令

一、命令简介 find 命令用于查找文档中的特定字符和数字及行号, 好比, 我们在阅读文档时, 使用的快捷键 Ctrl F 来查找是一个效果, 经过 find 查找的字符也可以重定向到一个文本文档里面去, 提取特定的字符, 来进行文档的整合。 二、使用示例 1、获取命令帮助 使用 find /?…

linux find命令

一、find命令语法格式&#xff1a; find [路径] [选项] [操作] 选项参数对照表&#xff1a; 三、常用选项 -name  查找 /etc 目录下以 conf 结尾的文件&#xff0c;文件名区分大小写&#xff0c;例如&#xff1a;find /etc -name *.conf -iname 查找当前目录下所有文件名…

find命令之exec

find命令结合exec find命令之exec find命令结合exec find命令结合execexecexec参数说明使用实例1. 查找当前目录下的文件&#xff0c;并对查找结果执行ls -l 命令2. 查找当前目录下&#xff0c;24小时内更改过的文件&#xff0c;并进行删除操作&#xff08;慎用&#xff01;&a…

Find 命令详解

find命令详解 命令语法格式&#xff1a;find查找路径查找条件信息 查找路径是指查找范围&#xff0c;使用该命令时需要指定一个范围&#xff0c;在该范围内查找。 查找条件分类&#xff1a; ①按文件名称查找 -name文件名称 ②按文件类型查找 &#xff08;文件类型又分为普通…

Linux命令之find命令

一、命令简介 Linux find 命令用来在指定目录下查找文件。任何位于参数之前的字符串都将被视为欲查找的目录名。如果使用该命令时&#xff0c;不设置任何参数&#xff0c;则 find 命令将在当前目录下查找子目录与文件。并且将查找到的子目录和文件全部进行显示。find 命令有非常…

Find命令的7种用法

Find对于技术面试&#xff0c;它也是一个热门话题。让我们看一道真题&#xff1a; 如果你的 Linux 服务器上有一个名为 logs 的目录&#xff0c;如何删除该目录下最后一次访问时间超过一年的日志文件呢&#xff1f; 这种情况很常见&#xff0c;但令人惊讶的是&#xff0c;并非…

find命令,详细

find命令&#xff0c;查找文件和目录 find查找命令是Linux系统中最重要和最常用的命令之一。查找用于根据与参数匹配的文件指定的条件来搜索和查找文件和目录列表的命令。查找可以在各种条件下使用&#xff0c;您可以通过权限&#xff0c;用户&#xff0c;组&#xff0c;文件类…

Linux常用命令——find命令大全

一、find命令常用功能 1、find命令的基本信息如下。 命令名称&#xff1a;find。英文原意&#xff1a;search for files in a directory hierarchy。所在路径&#xff1a;/bin/find。执行权限&#xff1a;所有用户。功能描述&#xff1a;在目录中搜索文件。 2、按照文件名搜…

linux内存管理系统

1. linux内存管理系统 1. 1 内存配置 vim .config 由上图可知&#xff0c;当前系统配置的内存资源为&#xff1a; 虚拟页大小4KiB 虚拟地址带宽48bit 物理地址带宽48bit 4级页表&#xff0c;pgd pud pmd pte 1.2 查看内存页的布局情况 make menuconfig利用qemu环境进行…

Linux内存管理详解

前一段时间看了《深入理解Linux内核》对其中的内存管理部分花了不少时间&#xff0c;但是还是有很多问题不是很清楚&#xff0c;最近又花了一些时间复习了一下&#xff0c;在这里记录下自己的理解和对Linux中内存管理的一些看法和认识。 我比较喜欢搞清楚一个技术本身的发展历程…

深入理解Linux内存管理

1.1 内存管理的意义1.2 原始内存管理1.3 分段内存管理1.4 分页内存管理1.5 内存管理的目标1.6 Linux内存管理体系2.1 物理内存节点2.2 物理内存区域2.3 物理内存页面2.4 物理内存模型2.5 三级区划关系3.1 Buddy System 3.1.1 伙伴系统的内存来源3.1.2 伙伴系统的管理数据结构3.…

【linux kernel】linux内存管理 | 分配物理内存页面

文章目录 一、物理内存分配概述二、分配核心函数&#xff08;__alloc_pages_nodemask&#xff09;&#xff08;2-1&#xff09;重要函数1&#xff1a;&#xff08;get_page_from_freelist()&#xff09;&#xff08;2-2-1&#xff09;for_each_zone_zonelist_nodemask{} &#…