热门标签 | 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


推荐阅读
  • selenium通过JS语法操作页面元素
    做过web测试的小伙伴们都知道,web元素现在很多是JS写的,那么既然是JS写的,可以通过JS语言去操作页面,来帮助我们操作一些selenium不能覆盖的功能。问题来了我们能否通过 ... [详细]
  • 本文介绍如何使用 Python 计算两个时间戳之间的时间差,并将其转换为毫秒。示例代码展示了如何通过 `time` 和 `datetime` 模块实现这一功能。 ... [详细]
  • 使用 ModelAttribute 实现页面数据自动填充
    本文介绍了如何利用 Spring MVC 中的 ModelAttribute 注解,在页面跳转后自动填充表单数据。主要探讨了两种实现方法及其背后的原理。 ... [详细]
  • Docker基础入门与环境配置指南
    本文介绍了Docker——一款用Go语言编写的开源应用程序容器引擎。通过Docker,用户能够将应用及其依赖打包进容器内,实现高效、轻量级的虚拟化。容器之间采用沙箱机制,确保彼此隔离且资源消耗低。 ... [详细]
  • 本文介绍了一个来自AIZU ONLINE JUDGE平台的问题,即清洁机器人2.0。该问题来源于某次编程竞赛,涉及复杂的算法逻辑与实现技巧。 ... [详细]
  • egg实现登录鉴权(七):权限管理
    权限管理包含三部分:访问页面的权限,操作功能的权限和获取数据权限。页面权限:登录用户所属角色的可访问页面的权限功能权限:登录用户所属角色的可访问页面的操作权限数据权限:登录用户所属 ... [详细]
  • 本报告记录了嵌入式软件设计课程中的第二次实验,主要探讨了使用KEIL V5开发环境和ST固件库进行GPIO控制及按键响应编程的方法。通过实际操作,加深了对嵌入式系统硬件接口编程的理解。 ... [详细]
  • 本文详细介绍了如何使用Rufus工具制作一个兼容UEFI启动模式的Windows Server 2008 R2安装U盘,包括必要的软件和步骤。 ... [详细]
  • 使用REM和媒体查询实现响应式布局
    本文介绍如何利用REM单位和媒体查询(Media Queries)来创建适应不同屏幕尺寸的网页布局。通过具体示例,展示在不同屏幕宽度下如何调整页面元素的样式。 ... [详细]
  • JavaScript 中引号的多层嵌套使用技巧
    本文详细介绍了在 JavaScript 编程中如何处理引号的多级嵌套问题,包括双引号、单引号以及转义字符的正确使用方法。 ... [详细]
  • 如何高效渲染JSON数据
    本文介绍了在控制器中返回JSON结果的方法,并详细说明了如何利用jQuery处理和展示这些数据,为Web开发提供了实用的技巧。 ... [详细]
  • Awk是一款功能强大的文本分析与处理工具,尤其在数据解析和报告生成方面表现突出。它通过读取由换行符分隔的记录,并按照指定的字段分隔符来划分和处理这些记录,从而实现复杂的数据操作。 ... [详细]
  • 深入解析Unity3D游戏开发中的音频播放技术
    在游戏开发中,音频播放是提升玩家沉浸感的关键因素之一。本文将探讨如何在Unity3D中高效地管理和播放不同类型的游戏音频,包括背景音乐和效果音效,并介绍实现这些功能的具体步骤。 ... [详细]
  • 本文探讨了一种常见的C++面试题目——实现自己的String类。通过此过程,不仅能够检验开发者对C++基础知识的掌握程度,还能加深对其高级特性的理解。文章详细介绍了如何实现基本的功能,如构造函数、析构函数、拷贝构造函数及赋值运算符重载等。 ... [详细]
  • 随着Linux操作系统的广泛使用,确保用户账户及系统安全变得尤为重要。用户密码的复杂性直接关系到系统的整体安全性。本文将详细介绍如何在CentOS服务器上自定义密码规则,以增强系统的安全性。 ... [详细]
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社区 版权所有