华为笔试

article/2025/10/11 6:49:50

目录

2017年4月21日华为笔试题 圣诞的祝福

2017年4月21日华为笔试题 德州扑克

2017年4月21日华为笔试题 日期的天数序号

2017华为笔试题 任务调度

2017华为笔试题 公司年会

2017华为笔试题 水仙花数

2018华为笔试题

2018华为笔试题2


2017年4月21日华为笔试题 圣诞的祝福

  • 简要描述: 给定一个M行N列的矩阵(M*N个格子),每个格子中放着一定数量的平安果。
    你从左上角的格子开始,只能向下或向右走,目的地是右下角的格子。
    每走过一个格子,就把格子上的平安果都收集起来。求你最多能收集到多少平安果。
    注意:当经过一个格子时,需要要一次性把格子里的平安果都拿走。
    限制条件:1 < N, M <= 50;每个格子里的平安果数量是0到1000(包含0和1000)。
  • 输入包括两行:
    第一行为矩阵的行数M和列数N
    第二行为一个M*N的矩阵,矩阵的数字代表平安果的数量,例如:
    1 2 3 40
    6 7 8 90
  • 输出一个数字,表示能收集到的平安果的数量

感觉这题很简单,直接一个动态规划的备忘录就解决了。

如果运行出现数组越界的情况,有2种情况

第一,访问了类似ans[-1][3]或者ans[3][-1]这样的

第二,数组刚好开小了一点点,然后当m=50,n=50的时候刚好越界

代码:

#include <iostream>
using namespace std;int m, n, num[50][50], ans[50][50];int f(int row, int line)
{if (ans[row][line] >= 0)return ans[row][line];if (row == 0 && line == 0)return num[0][0];if (row == 0)ans[row][line] = f(row, line - 1) + num[row][line];else if (line == 0)ans[row][line] = f(row - 1, line) + num[row][line];else{ans[row][line] = f(row, line - 1) + num[row][line];int k = f(row - 1, line) + num[row][line];if (ans[row][line] < k)ans[row][line] = k;}return ans[row][line];
}int main()
{cin >> m >> n;for (int i = 0; i < m; i++)for (int j = 0; j < n; j++){cin >> num[i][j];ans[i][j] = -1;}cout << f(m - 1, n - 1);return 0;
}

2017年4月21日华为笔试题 德州扑克

题目:

如果输入10,只读取1,0不管,这样就可以用"234567891JQKA"这13个字母表示13张牌了,写代码方便很多。

然后主要就是要理清楚这7种牌型之间的关系,首先按照最多有多少个数字是一样的,可以分成3大类。

第一类,有4个相同数字,一定是牌型2

第二类,有3个相同数字,是牌型3或6

第三类,没有任何3个数字相同,是牌型1或4或5或7

然后再细分就很简单。

代码:

#include <iostream>
using namespace std;char num[5], color[5];
const char an[14] = "234567891JQKA";bool num34(int n)//刚好有3或者4个相同的数字
{char c;for (int i = 0; i < 5; i++){c = num[i];int s = 0;for (int i = 0; i < 5; i++)if (num[i] == c)s++;if (s == n)return true;}return false;
}bool shun()//是不是顺子
{int m = 14;for (int i = 0; i < 5; i++)for (int j = 0; j < 13; j++)if (num[i] == an[j] && m>j)m = j;for (int j = m; j < m + 5; j++){bool flag = true;for (int i = 0; i < 5; i++)if (num[i] == an[j])flag = false;if (flag)return false;}return true;
}bool tonghua()//是不是同花
{for (int i = 1; i < 5; i++)if (color[i] != color[0])return false;return true;
}int f()
{if (num34(3)){char c;for (int i = 0; i < 5; i++){c = num[i];int s = 0;for (int i = 0; i < 5; i++)if (num[i] == c)s++;if (s == 1)return 6;}return 3;}if (num34(4))return 2;if (shun()){if (tonghua())return 1;return 5;}if (tonghua())return 4;return 7;
}int main()
{char c;for (int i = 0; i < 5; i++){cin >> num[i];if (num[i] == '1')cin >> c;cin >> color[i];}cout << f();return 0;
}

2017年4月21日华为笔试题 日期的天数序号

题目:

这个题目真的挺坑的,明明这么简单的题目,提交一直不对,还好我有一定的ACM经历,有几次碰到过这种情况,最后把最后的点删掉就可以了

代码:

#include <iostream>
using namespace std;bool r(int year)//第year年是不是闰年
{if (year % 4)return false;if (year % 100)return true;return year % 400 == 0;
}int main()
{int day[13] = { 0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31 };int y, m, d, s;char c;cin >> y >> c >> m >> c >> d;if (r(y))day[2]++;if (y <= 0 || y >= 10000 || m <= 0 || m > 12 || d <= 0 || d > day[m])cout << "invalid input";else{s = d;for (int i = 1; i < m; i++)s += day[i];printf("%d-%d-%d is the No.%d day of %d",y,m,d,s,y);}return 0;
}

2017华为笔试题 任务调度

题目描述:

输入5个任务的ID,任务优先级,开始运行时间和任务运行时间,其中调度过程支持抢占,即优先级值高的任务可抢占正在运行的优先级值低的任务,最后输出前200秒,任务的调度过程

输入描述:

任务信息输入格式为:[任务ID.任务优秀级.任务开始运行时间.任务运行时长];任务与任务之间使用“|”隔离;5个任务的任务ID为1-5;任务优先级范围为0-200.

输出描述:

任务ID.任务运行时长。任务与任务之间使用‘|’分割,无任务运行时ID为0。

输入例子:

[1.80.1.10]|[2.20.11.15]|[3.50.21.10]|[4.120.31.10]|[5.100.41.10]

输出例子:

0.1|1.10|2.10|3.10|4.10|5.10|2.5|0.144

这个似乎不难,不过写起来倒也麻烦。

反正不是我笔试,懒得写了。

2017华为笔试题 公司年会

题目:

这个题目如果用递归的函数的话,主要就是要避免死循环

代码(没地方提交,不知道对不对):

#include <iostream>
#include<algorithm>
using namespace std;int list[30], key = 0;void add(int a)
{if (key >= 30)return;for (int i = 0; i < key; i++)if (list[i] == a)return;list[key++] = a;
}void add(int a, int b, int c)
{	add(a), add(b), add(c);add(a * 10 + b), add(a * 10 + c);add(b * 10 + a), add(b * 10 + c);add(c * 10 + a), add(c * 10 + b);
}void add25(int a, int b, int c)//只考虑2和5
{add(a, b, c);if (a == 2 || a == 5)add(7 - a, b, c);if (b == 2 || b == 5)add(a, 7 - b, c);if (c == 2 || c == 5)add(a, b, 7 - c);
}void add69(int a, int b, int c)//只考虑6和9
{add25(a, b, c);if (a == 6 || a == 9)add25(15 - a, b, c);if (b == 6 || b == 9)add25(a, 15 - b, c);if (c == 6 || c == 9)add25(a, b, 15 - c);
}int main()
{int a, b, c;scanf("%d,%d,%d", &a, &b, &c);int m = a;if (m < b)m = b;if (m < c)m = c;add69(a, b, c);sort(list, list + key);cout << list[m - 1];return 0;
}

2017华为笔试题 水仙花数

题目描述:水仙花数是指一个n位数(n≥3),它的每个位上的数字的n次幂之和等于它本身。(例如:1³+5³+3³=153),要求:输出1000范围内所有水仙花数及水仙花数之和。

输入描述:无

输出描述:1000以内所有水仙花数及总和。

输出例子:

第1个水仙花数:xxx

第2个水仙花数:xxx

第3个水仙花数:xxx

...

水仙花数总和为:xxx

代码(没地方提交,不知道对不对):

#include <iostream>
using namespace std;/*
bool narcissus(int n)
{int a = n / 100, b = n / 10 % 10, c = n % 10;return a*a*a + b*b*b + c*c*c == a * 100 + b * 10 + c;
}int main()
{int sum = 0;for (int i = 100; i < 1000; i++)if (narcissus(i)){cout << i << endl;sum += i;}cout << sum;return 0;
}
*/int main()
{cout << "第1个水仙花数:" << 153 << "\n第2个水仙花数:" << 370 << "\n第3个水仙花数:" << 371 << "\n第4个水仙花数:" << 407 << "\n水仙花数总和为:" << 1301;return 0;
}

2018华为笔试题

代码:

#include<iostream>
using namespace std;int main()
{long long n, M, N, list[51];cin >> n;list[0] = 1, list[1] = 2, list[2] = 3, list[3] = 4;for (int i = 4; i <= 50; i++)list[i] = list[i - 1] + list[i - 4];while (n--){cin >> M >> N;cout << list[N] * M << endl;}return 0;
}

2018华为笔试题2

示例1

输入

1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1

输出

0
2
0
4
0
6
0
8
0
10
0
8
0
6
0
4
0
2

代码:

#include<iostream>
using namespace std;struct node
{int shi, xu;
}nod[11];int getshi(int a, int b)
{return nod[a].shi*nod[b].shi - nod[a].xu*nod[b].xu;
}int getxu(int a, int b)
{return nod[a].shi*nod[b].xu + nod[a].xu*nod[b].shi;
}int main()
{for (int i = 1; i <= 10; i++)cin >> nod[i].shi >> nod[i].xu;cout << getshi(1, 6) << endl;cout << getxu(1, 6) << endl;cout << getshi(1, 7) + getshi(2, 6) << endl;cout << getxu(1, 7) + getxu(2, 6) << endl;cout << getshi(1, 8) + getshi(2, 7) + getshi(3, 6) << endl;cout << getxu(1, 8) + getxu(2, 7) + getxu(3, 6) << endl;cout << getshi(1, 9) + getshi(2, 8) + getshi(3, 7) + getshi(4, 6) << endl;cout << getxu(1, 9) + getxu(2, 8) + getxu(3, 7) + getxu(4, 6) << endl;cout << getshi(1, 10) + getshi(2, 9) + getshi(3, 8) + getshi(4, 7) + getshi(5, 6) << endl;cout << getxu(1, 10) + getxu(2, 9) + getxu(3, 8) + getxu(4, 7) + getxu(5, 6) << endl;cout << getshi(2, 10) + getshi(3, 9) + getshi(4, 8) + getshi(5, 7) << endl;cout << getxu(2, 10) + getxu(3, 9) + getxu(4, 8) + getxu(5, 7) << endl;cout << getshi(3, 10) + getshi(4, 9) + getshi(5, 8) << endl;cout << getxu(3, 10) + getxu(4, 9) + getxu(5, 8) << endl;cout << getshi(4, 10) + getshi(5, 9) << endl;cout << getxu(4, 10) + getxu(5, 9) << endl;cout << getshi(5, 10) << endl;cout << getxu(5, 10) << endl;return 0;
}


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

相关文章

1.华为实习笔试

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

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.…