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


推荐阅读
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • HDU 2372 El Dorado(DP)的最长上升子序列长度求解方法
    本文介绍了解决HDU 2372 El Dorado问题的一种动态规划方法,通过循环k的方式求解最长上升子序列的长度。具体实现过程包括初始化dp数组、读取数列、计算最长上升子序列长度等步骤。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 基于layUI的图片上传前预览功能的2种实现方式
    本文介绍了基于layUI的图片上传前预览功能的两种实现方式:一种是使用blob+FileReader,另一种是使用layUI自带的参数。通过选择文件后点击文件名,在页面中间弹窗内预览图片。其中,layUI自带的参数实现了图片预览功能。该功能依赖于layUI的上传模块,并使用了blob和FileReader来读取本地文件并获取图像的base64编码。点击文件名时会执行See()函数。摘要长度为169字。 ... [详细]
  • 本文讨论了Alink回归预测的不完善问题,指出目前主要针对Python做案例,对其他语言支持不足。同时介绍了pom.xml文件的基本结构和使用方法,以及Maven的相关知识。最后,对Alink回归预测的未来发展提出了期待。 ... [详细]
  • 本文介绍了闭包的定义和运转机制,重点解释了闭包如何能够接触外部函数的作用域中的变量。通过词法作用域的查找规则,闭包可以访问外部函数的作用域。同时还提到了闭包的作用和影响。 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 开发笔记:加密&json&StringIO模块&BytesIO模块
    篇首语:本文由编程笔记#小编为大家整理,主要介绍了加密&json&StringIO模块&BytesIO模块相关的知识,希望对你有一定的参考价值。一、加密加密 ... [详细]
  • 目录实现效果:实现环境实现方法一:基本思路主要代码JavaScript代码总结方法二主要代码总结方法三基本思路主要代码JavaScriptHTML总结实 ... [详细]
  • 本文介绍了C#中数据集DataSet对象的使用及相关方法详解,包括DataSet对象的概述、与数据关系对象的互联、Rows集合和Columns集合的组成,以及DataSet对象常用的方法之一——Merge方法的使用。通过本文的阅读,读者可以了解到DataSet对象在C#中的重要性和使用方法。 ... [详细]
  • 本文主要解析了Open judge C16H问题中涉及到的Magical Balls的快速幂和逆元算法,并给出了问题的解析和解决方法。详细介绍了问题的背景和规则,并给出了相应的算法解析和实现步骤。通过本文的解析,读者可以更好地理解和解决Open judge C16H问题中的Magical Balls部分。 ... [详细]
  • 本文介绍了在SpringBoot中集成thymeleaf前端模版的配置步骤,包括在application.properties配置文件中添加thymeleaf的配置信息,引入thymeleaf的jar包,以及创建PageController并添加index方法。 ... [详细]
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社区 版权所有