2014华为机试西安地区A组试题
2014华为机试西安地区A组试题
题目一、分苹果
M个同样苹果放到N个同样篮子里有多少种放法,同意有篮子不放。
1<=M<=10。1<=N<=10
比如5个苹果三个篮子,3,1,1 和 1,1,3是同一种放法
输入 7 3
输出 8
题目分析:
这道题相似于整数划分的题目。这是非常早的一道ACM的题目,主要思路就是考递归。
①当苹果数目或者篮子数目为1时候,就仅仅有一种可能
②当苹果数目小于篮子数目的时候。依照苹果数目来分配
③当苹果数目大于篮子数目的时候。空一个盘子 + 先每一个盘子放一个之后再m-n个随便放
③当苹果数目等于篮子数目的时候,每一个盘子放一个 + 空一个盘子
=========================================================================
參考代码:
//分苹果.cpp
//2014.7.12 hepanhui
#include <iostream>
using namespace std;
int SharingApple(int m, int n)
{
if(m == 1 || n == 1)
return 1;
if(m < n)
return SharingApple(m , m);
else if(m > n)
return SharingApple(m, n-1) + SharingApple(m-n, n);
else
return 1 + SharingApple(m, n-1);
}
int main()
{
int M,N;
cin >> M >> N;
cout << SharingApple(M,N) << endl;
return 0;
}
调试过程中易犯错的地方:
①苹果数小于篮子数目的时候,直接依照苹果来分配。不是SharingApple(n, n)哦。
②m == 1不能笔误写成=
题目二:算日期
输入一个日期,输出这是这一年的第几天。(题目中没有给出闰年的定义)
输入 20131231
输出 365
题目分析:
该题目主要考察switch语句的使用和润年的推断;还需要注意的是输入的时候没有空格,说明我们不知道哪个是年哪个是月哪个是日,所以我们要看成一个字符串的输入。
======================================================================
參考代码:
//算日期.cpp
//2014.7.12 hepanhui
#include <iostream>
#include <string>
using namespace std;
int CalculatingDate(int year, int month, int day)
{
int flag = 0;
if(year % 400 == 0 || (year % 4 == 0 && year % 100 != 0))
flag = 1;
int cnt = 0;
for(int i = 1;i < month; i++)
{
switch(i)
{
case 1:
case 3:
case 5:
case 7:
case 8:
case 10: cnt += 31;break;
case 2: cnt += 28 + flag;break;
case 4:
case 6:
case 9:
case 11: cnt += 30;break;
}
}
cnt += day;
return cnt;
}
int main()
{
string str;
int year,month,day;
cin >> str;
year = (str[0] - '0') * 1000 + (str[1] -'0') * 100 + (str[2] - '0') * 10 + (str[3] - '0');
month = (str[4] - '0') * 10 + str[5] - '0';
day = (str[6] - '0') * 10 + str[7] - '0';
cout << CalculatingDate(year,month,day) << endl;
return 0;
}
调试中易犯的错误:
①注意switch语句的写法,记住不一样的情况应该加上break
②注意输入必需要看成字符串。再转化成整型
③注意string输入的时候,一定要加上头文件#include<string>
2014华为机试西安地区A组试题的更多相关文章
- 2014华为机试西安地区B组试题
2014华为机试西安地区B组试题 题目一.亮着点灯的盏数 一条长廊里依次装有n(1≤n≤65535)盏电灯,从头到尾编号1.2.3.-n-1.n.每盏电灯由一个拉线开关控制.開始,电灯所有关着. 有n ...
- 华为机试001:字符串最后一个单词的长度(华为OJ001)
华为机试 字符串最后一个单词的长度 计算字符串最后一个单词的长度,单词以空格隔开. 提交网址: http://www.nowcoder.com/practice/8c949ea5f36f422594b ...
- 华为机试ACM(字符组合问题)
今晚做了华为的机试,3道ACM题,最后一道是实现从M个不同字符中任取N个字符的所有组合. eg: input:ABC 2 output:AB AC BC 第一个输入为字符串,第二个输入为组合的字符个数 ...
- 华为机试正式版(西安c/c++/java),今天下午去机试的题目,新奇出炉了!
下面题目都是回顾的.题目都非常easy, 大家有些基础就能够參加!(语言能够是c/c++.也能够是java的) 题目一(60分): 字符串操作. 将小写转换成大写, 将大写转化为小写, 数字的不做转换 ...
- 【华为机试】找最高分(通过此题熟悉牛客网Node输入输出)
来源:牛客网 老师想知道从某某同学当中,分数最高的是多少,现在请你编程模拟老师的询问.当然,老师有时候需要更新某位同学的成绩. 输入描述: 输入包括多组测试数据.每组输入第一行是两个正整数N和M(0 ...
- 华为机试_字符串识别_Vector的使用;
第一题:拼音转数字输入是一个只包含拼音的字符串,请输出对应的数字序列.转换关系如下:描述: 拼音 yi er san si wu liu qi ba jiu ...
- 输入一个字符串,去掉重复的字符,并按ASCII值排序-华为机试
import java.util.Scanner; //输入字符串,去掉重复的字符,并按ASSIC码值排序 public class quChong { public static void main ...
- 2015华为机试——数字基root
题目描写叙述: 求整数的Root:给定正整数,求每位数字之和;假设和不是一位数,则反复; 输入:输入随意一个或多个整数 输出:输出各位数字之和,直到和为个位数为止(输入异常,则返回-1),多行,每行相 ...
- 华为机试 之 joseph环
一:首先科普一下约瑟夫问题的数学方法 (1) 不管是用list实现还是用vector实现都有一个共同点:要模拟整个游戏过程,不仅程序写起来比較烦,并且时间复杂度高达O(nm),当n,m很大(比如上百 ...
随机推荐
- Confluence 6 导入 Active Directory 服务器证书 - UNIX
为了让你的应用服务器能够信任你的目录服务器.你目录服务器上导出的证书需要导入到你应用服务器的 Java 运行环境中.JDK 存储了信任的证书,这个存储信任证书的文件称为一个 keystore.默认的 ...
- 双机热备(准)-->RAC(夭折)-->DG(异地容灾)
以下有的地方为oracle专业术语,非懂勿喷.前段时间某项目负责人告知,他们应用需要一套oracle数据库环境运行模式为双机热备.简单了解下对于现在已经非常成熟的RAC再合适不过了.详细问了问当前服务 ...
- 小程序中的bindtap和catchtap的区别(交流QQ群:604788754)
bindtap绑定的节点,如果他的父节点也有绑定事件,点击之后就会出现冒泡. catchtap绑定的节点,如果他的父节点也有绑定事件,点击之后不会出现冒泡.
- Android轮播图Banner的实现
从慕课网上学了一门叫做“不一样的自定义实现轮播图效果”的课程,感觉实用性较强,而且循序渐进,很适合初学者.在此对该课程做一个小小的笔记. 实现轮播思路: 1.一般轮播图是由一组图片和底部轮播圆点组成, ...
- jdk1.6中bin目录下的工具及其作用
jdk的javaw.javac等的介绍java:在msdos终端窗口中执行.class文件,即解释执行.class文件.通常所说的jvm解释权.javaw:在java自己的窗口中执行.class文件而 ...
- Oracle 从共享池删除指定SQL的执行计划
ORACLE从共享池删除指定SQL的执行计划 2016-12-29 11:14 by 潇湘隐者, 2836 阅读, 0 评论, 收藏, 编辑 Oracle 11g在DBMS_SHARED_POOL包中 ...
- 没有添加spring mvc 默认依赖包产生的错误
启动tomcat的时候提示:java.lang.IllegalStateException: ContainerBase.addChild: start: org.apache.catalina.Li ...
- 内核事件KEVENT(同步)
转载请您注明出处:http://www.cnblogs.com/lsh123/p/7358702.html 一.驱动程序与驱动程序的事件交互 IoCreateNotificationEvent ...
- avalonJS-源码阅读(3) VMODEL
来源 avalon的重头戏.终于要到我最期待的vmodel了. ps:这篇博文想做的全一点,错误少一点,所以会有后续的更新在这篇文章中. 状态:一稿 目录[-] avalon dom小结 数据结构 观 ...
- anu - react
import { options } from "./util"; import { Children } from "./Children"; import ...