2014华为机试西安地区A组试题

题目一、分苹果
M个同样苹果放到N个同样篮子里有多少种放法,同意有篮子不放。
1<=M<=10。1<=N<=10
比如5个苹果三个篮子,3,1,1 和 1,1,3是同一种放法

输入 7 3
输出 8
题目分析:
这道题相似于整数划分的题目。这是非常早的一道ACM的题目,主要思路就是考递归。
①当苹果数目或者篮子数目为1时候,就仅仅有一种可能
②当苹果数目小于篮子数目的时候。依照苹果数目来分配
③当苹果数目大于篮子数目的时候。空一个盘子 + 先每一个盘子放一个之后再m-n个随便放
③当苹果数目等于篮子数目的时候,每一个盘子放一个 + 空一个盘子

=========================================================================
參考代码:

  1. //分苹果.cpp
  2. //2014.7.12 hepanhui
  3. #include <iostream>
  4. using namespace std;
  5. int SharingApple(int m, int n)
  6. {
  7. if(m == 1 || n == 1)
  8. return 1;
  9. if(m < n)
  10. return SharingApple(m , m);
  11. else if(m > n)
  12. return SharingApple(m, n-1) + SharingApple(m-n, n);
  13. else
  14. return 1 + SharingApple(m, n-1);
  15. }
  16. int main()
  17. {
  18. int M,N;
  19. cin >> M >> N;
  20. cout << SharingApple(M,N) << endl;
  21. return 0;
  22. }

调试过程中易犯错的地方:
①苹果数小于篮子数目的时候,直接依照苹果来分配。不是SharingApple(n, n)哦。

②m == 1不能笔误写成=

题目二:算日期
输入一个日期,输出这是这一年的第几天。(题目中没有给出闰年的定义)

输入 20131231
输出 365
题目分析:
该题目主要考察switch语句的使用和润年的推断;还需要注意的是输入的时候没有空格,说明我们不知道哪个是年哪个是月哪个是日,所以我们要看成一个字符串的输入。

======================================================================
參考代码:

  1. //算日期.cpp
  2. //2014.7.12 hepanhui
  3. #include <iostream>
  4. #include <string>
  5. using namespace std;
  6. int CalculatingDate(int year, int month, int day)
  7. {
  8. int flag = 0;
  9. if(year % 400 == 0 || (year % 4 == 0 && year % 100 != 0))
  10. flag = 1;
  11. int cnt = 0;
  12. for(int i = 1;i < month; i++)
  13. {
  14. switch(i)
  15. {
  16. case 1:
  17. case 3:
  18. case 5:
  19. case 7:
  20. case 8:
  21. case 10: cnt += 31;break;
  22. case 2: cnt += 28 + flag;break;
  23. case 4:
  24. case 6:
  25. case 9:
  26. case 11: cnt += 30;break;
  27. }
  28. }
  29. cnt += day;
  30. return cnt;
  31. }
  32. int main()
  33. {
  34. string str;
  35. int year,month,day;
  36. cin >> str;
  37. year = (str[0] - '0') * 1000 + (str[1] -'0') * 100 + (str[2] - '0') * 10 + (str[3] - '0');
  38. month = (str[4] - '0') * 10 + str[5] - '0';
  39. day = (str[6] - '0') * 10 + str[7] - '0';
  40. cout << CalculatingDate(year,month,day) << endl;
  41. return 0;
  42. }

调试中易犯的错误:
①注意switch语句的写法,记住不一样的情况应该加上break
②注意输入必需要看成字符串。再转化成整型
③注意string输入的时候,一定要加上头文件#include<string>

2014华为机试西安地区A组试题的更多相关文章

  1. 2014华为机试西安地区B组试题

    2014华为机试西安地区B组试题 题目一.亮着点灯的盏数 一条长廊里依次装有n(1≤n≤65535)盏电灯,从头到尾编号1.2.3.-n-1.n.每盏电灯由一个拉线开关控制.開始,电灯所有关着. 有n ...

  2. 华为机试001:字符串最后一个单词的长度(华为OJ001)

    华为机试 字符串最后一个单词的长度 计算字符串最后一个单词的长度,单词以空格隔开. 提交网址: http://www.nowcoder.com/practice/8c949ea5f36f422594b ...

  3. 华为机试ACM(字符组合问题)

    今晚做了华为的机试,3道ACM题,最后一道是实现从M个不同字符中任取N个字符的所有组合. eg: input:ABC 2 output:AB AC BC 第一个输入为字符串,第二个输入为组合的字符个数 ...

  4. 华为机试正式版(西安c/c++/java),今天下午去机试的题目,新奇出炉了!

    下面题目都是回顾的.题目都非常easy, 大家有些基础就能够參加!(语言能够是c/c++.也能够是java的) 题目一(60分): 字符串操作. 将小写转换成大写, 将大写转化为小写, 数字的不做转换 ...

  5. 【华为机试】找最高分(通过此题熟悉牛客网Node输入输出)

    来源:牛客网 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问.当然,老师有时候需要更新某位同学的成绩. 输入描述: 输入包括多组测试数据.每组输入第一行是两个正整数N和M(0 ...

  6. 华为机试_字符串识别_Vector的使用;

    第一题:拼音转数字输入是一个只包含拼音的字符串,请输出对应的数字序列.转换关系如下:描述:      拼音        yi  er  san  si  wu  liu  qi  ba  jiu  ...

  7. 输入一个字符串,去掉重复的字符,并按ASCII值排序-华为机试

    import java.util.Scanner; //输入字符串,去掉重复的字符,并按ASSIC码值排序 public class quChong { public static void main ...

  8. 2015华为机试——数字基root

    题目描写叙述: 求整数的Root:给定正整数,求每位数字之和;假设和不是一位数,则反复; 输入:输入随意一个或多个整数 输出:输出各位数字之和,直到和为个位数为止(输入异常,则返回-1),多行,每行相 ...

  9. 华为机试 之 joseph环

    一:首先科普一下约瑟夫问题的数学方法 (1)  不管是用list实现还是用vector实现都有一个共同点:要模拟整个游戏过程,不仅程序写起来比較烦,并且时间复杂度高达O(nm),当n,m很大(比如上百 ...

随机推荐

  1. git log 查找

    查找含有某个字符串的 commit git log --grep=224 // 这条命令是查看含有 "224" 关键字的 git commit 查看某个作者 git log --a ...

  2. 『cs231n』作业2选讲_通过代码理解优化器

    1).Adagrad一种自适应学习率算法,实现代码如下: cache += dx**2 x += - learning_rate * dx / (np.sqrt(cache) + eps) 这种方法的 ...

  3. UVA-818 Cutting Chains (位压缩+暴力搜索)

    题目大意:一种环能打开和闭合.现在有n(1<=n<=15)个编号为1~n的环错综复杂的连接着,要打开一些环重新连接使这n个环能构成一条链,问最少需要打开几次环可达到目的? 题目分析:用二进 ...

  4. HDU-4471 Yet Another Multiple Problem (BFS+路径还原)

    Problem Description There are tons of problems about integer multiples. Despite the fact that the to ...

  5. Leetcode 94

    /** * Definition for a binary tree node. * struct TreeNode { * int val; * TreeNode *left; * TreeNode ...

  6. AIX5L内存监控和调整

    1.ps ps gv | head -n 1; ps gv | egrep -v "RSS" | sort +6b -7 -n -r PID      TTY    STAT    ...

  7. Logger.getLogger()和LogFactory.getLog()的区别

    第一.Logger.getLogger()和LogFactory.getLog()的区别 1.Logger.getLogger()是使用log4j的方式记录日志: 2.LogFactory.getLo ...

  8. learning uboot test command

    uboot commad test test - minimal test like /bin/sh so we can use test command to some judge for exam ...

  9. 设置xml中控件的圆润边框效果

    <?xml version="1.0" encoding="utf-8"?> <shape xmlns:android="http: ...

  10. CodeIgniter $this->db->where()的自定义语句写法问题

    .自定义字符串:你可以手动的编写子句:$where = "name='Joe' AND status='boss' OR status='active'"; $this->d ...