热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

2014年华为实习机试题总结

昨天刚从杭州旅游回来,晚上11点到的南京,今天一早起来去华为参加机试,果然犯了很傻*的错误。中午回来之后回忆了没做出来的两道题目(是的,我只出来一道完整的中级题,请鄙视我吧!),花

昨天刚从杭州旅游回来,晚上11点到的南京,今天一早起来去华为参加机试,果然犯了很傻*的错误。中午回来之后回忆了没做出来的两道题目(是的,我只出来一道完整的中级题,请鄙视我吧!),花了一个小时做出来,给大家参考一下。

第一题:X个人去吃饭,消费Y元(X,Y为整数输入),其中男人消费3RMB/人,女人2RMB/人,小孩1RMB/人,问:一共有多少种可能的消费组合(小孩,男人,女人至少各一个的组合才算有效组合)?

这题其实很简单,就是循环嵌套,居然。。。当时懵了。。。不多说,说多了都是泪,上代码:



1 import java.util.Scanner;
2
3
4 public class Main {
5
6 /**
7 * @param args
8 */
9 public static void main(String[] args) {
10 // TODO Auto-generated method stub
11 Scanner cin = new Scanner(System.in);
12 int x = cin.nextInt();
13 int y = cin.nextInt();
14 int result = 0;
15
16 if(x <0 || y <0){
17 System.out.println(result);
18 }else
19 result++;
20 int a, b, c;
21 for(int i=0; i<=x; i++){
22 a = i;
23 for(int j=0; j<=x; j++){
24 b = j;
25 for(int m=0; m<=x; m++){
26 c = m;
27 if((a+b+c==x) && (3*a+2*b+c==y)){
28 result++;
29 }
30 }
31 }
32 }
33 System.out.println(result);
34
35 }
36 }

第三道高级题,其实也简单,思路很清晰,但是楼主又死在了要遍历3^8种所有组合的循环嵌套上(根本没想到这么暴力的方法啊),那一刻楼主仿佛从未学过编程。。。

输入一个整数X,问:“123456789”在数字中间插入“+”或者“-”使这个式子(如1+23-45+6-7-89)的运算结果等于X的组合有多少种?(大概就这意思,具体的表述我也记不清了)例如:输入5,应该输出21



1 import java.util.Scanner;
2
3
4 public class Main {
5
6 /**
7 * @param args
8 */
9 public static void main(String[] args) {
10 // TODO Auto-generated method stub
11 Scanner cin = new Scanner(System.in);
12 int x = cin.nextInt();
13
14 int count = 0;
15 String[] f = {"1", "", "2", "", "3", "", "4", "", "5", "", "6", "", "7", "", "8", "", "9"};
16 String[] op = {"+", "-", ""};
17 String target = "";
18
19 for(int a=0; a){
20 f[1] = op[a];
21 for(int b=0; b){
22 f[3] = op[b];
23 for(int c=0; c){
24 f[5] = op[c];
25 for(int d=0; d){
26 f[7] = op[d];
27 for(int e=0; e){
28 f[9] = op[e];
29 for(int g=0; g){
30 f[11] = op[g];
31 for(int h=0; h){
32 f[13] = op[h];
33 for(int i=0; i){
34 f[15] = op[i];
35 for(int j=0; j){
36 target = target + f[j];
37 }
38 if(x == compute(target)){
39 // System.out.println(target);
40 count++;
41 }
42 target = "";
43 }
44 }
45 }
46 }
47 }
48 }
49 }
50 }
51 System.out.println(count);
52 // System.out.println(compute("1+2+3-4+5+6-7-8"));
53 }
54
55 public static int compute(String target){
56 while(target.contains("+") || target.contains("-")){
57 if(target.contains("+")){
58 return compute(target.substring(0, target.indexOf("+"))) +
59 compute(target.substring(target.indexOf("+") + 1));
60
61 }else{
62 return compute(target.substring(0, target.lastIndexOf("-"))) -
63 compute(target.substring(target.lastIndexOf("-") + 1));
64 }
65 }
66 return Integer.parseInt(target);
67 }
68 }

2014年华为实习机试题总结,布布扣,bubuko.com


推荐阅读
  • 本文介绍如何通过Windows批处理脚本定期检查并重启Java应用程序,确保其持续稳定运行。脚本每30分钟检查一次,并在需要时重启Java程序。同时,它会将任务结果发送到Redis。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • Vue 2 中解决页面刷新和按钮跳转导致导航栏样式失效的问题
    本文介绍了如何通过配置路由的 meta 字段,确保 Vue 2 项目中的导航栏在页面刷新或内部按钮跳转时,始终保持正确的 active 样式。具体实现方法包括设置路由的 meta 属性,并在 HTML 模板中动态绑定类名。 ... [详细]
  • 深入理解 Oracle 存储函数:计算员工年收入
    本文介绍如何使用 Oracle 存储函数查询特定员工的年收入。我们将详细解释存储函数的创建过程,并提供完整的代码示例。 ... [详细]
  • 本文总结了2018年的关键成就,包括职业变动、购车、考取驾照等重要事件,并分享了读书、工作、家庭和朋友方面的感悟。同时,展望2019年,制定了健康、软实力提升和技术学习的具体目标。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • Linux 系统启动故障排除指南:MBR 和 GRUB 问题
    本文详细介绍了 Linux 系统启动过程中常见的 MBR 扇区和 GRUB 引导程序故障及其解决方案,涵盖从备份、模拟故障到恢复的具体步骤。 ... [详细]
  • 本文介绍了如何使用jQuery根据元素的类型(如复选框)和标签名(如段落)来获取DOM对象。这有助于更高效地操作网页中的特定元素。 ... [详细]
  • 本文介绍如何在 Xcode 中使用快捷键和菜单命令对多行代码进行缩进,包括右缩进和左缩进的具体操作方法。 ... [详细]
  • 在Linux系统中配置并启动ActiveMQ
    本文详细介绍了如何在Linux环境中安装和配置ActiveMQ,包括端口开放及防火墙设置。通过本文,您可以掌握完整的ActiveMQ部署流程,确保其在网络环境中正常运行。 ... [详细]
  • 本文介绍如何通过SQL查询从JDE(JD Edwards)系统中提取所有字典数据,涵盖关键表的关联和字段选择。具体包括F0004和F0005系列表的数据提取方法。 ... [详细]
  • 本文详细介绍了如何通过命令行启动MySQL服务,包括打开命令提示符窗口、进入MySQL的bin目录、输入正确的连接命令以及注意事项。文中还提供了更多相关命令的资源链接。 ... [详细]
  • 本文探讨了如何通过最小生成树(MST)来计算严格次小生成树。在处理过程中,需特别注意所有边权重相等的情况,以避免错误。我们首先构建最小生成树,然后枚举每条非树边,检查其是否能形成更优的次小生成树。 ... [详细]
  • 几何画板展示电场线与等势面的交互关系
    几何画板是一款功能强大的物理教学软件,具备丰富的绘图和度量工具。它不仅能够模拟物理实验过程,还能通过定量分析揭示物理现象背后的规律,尤其适用于难以在实际实验中展示的内容。本文将介绍如何使用几何画板演示电场线与等势面之间的关系。 ... [详细]
author-avatar
dsgfg
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有