2014 华为校招机试题(c/c++开发类)
第一题:
1、2、3.。。。n盏灯,同时有n个人,
第1个人将1的倍数的灯拉一下,
第2个人将2的倍数的灯拉一下,
......
问最后有几盏灯是亮的,
初始状态下灯是灭的,
输入整数n(n<65536),
输出亮的灯数
方法解析:设置一个map,关键字为灯的编号,值为0或1,分别表示灯灭和灯亮状态,遍历map,第i个灯,将所有i倍数的灯进行一次取反操作,也可以通过数组实现。代码如下:
- #include "stdafx.h"
- #include <iostream>
- #include <vector>
- #include <map>
- using namespace std;
- int count1(int n)
- {
- vector<int> vec(65536, 0);
- for (int i = 1; i <= n; i++)
- {
- for (int j = 1; j <= n;j++)
- {
- if (j%i== 0)
- vec[j - 1] = !vec[j - 1];;
- }
- }
- int sum = 0;
- for (int j = 0; j < n; j++)
- {
- if (vec[j] != 0) //统计灯泡亮着的个数
- sum++;
- }
- return sum;
- }
- int count2(int n)
- {
- map<int, int> m;
- for (int i = 1; i <= n; i++) //初始化map
- m.insert({ i, 0 });
- for (int j = 1; j <= n; j++)
- {
- for (auto it = m.begin(); it != m.end(); it++)
- {
- if (it->first%j == 0)
- it->second = !(it->second);
- }
- }
- int sum = 0;
- for (auto it = m.begin(); it != m.end(); it++)
- if (it->second == 1)
- sum++;
- return sum;
- }
- int count3(int n)
- {
- int sum = 0;
- bool a[65536] = { 0 };
- for (int i = 1; i <= n; i++) //通过两嵌套循环模拟N个人一次拉灯
- {
- for (int j = 1; j <= n; j++)
- {
- if (j % i == 0)
- {
- a[j - 1] = !a[j - 1];
- }
- }
- }
- for (int j = 0; j < n; j++)
- {
- if (a[j] != 0) //统计灯泡亮着的个数
- sum++;
- }
- return sum;
- }
- int _tmain(int argc, _TCHAR* argv[])
- {
- int number1 = count1(100);
- cout << number1 << endl;
- return 0;
- }
第二题:
输入整数(n是小于9位数的整数),当作字符串处理,看是否有相同的子串,如1212,相同子串是12,141516没有子串(子串必须大于等于2),若有相同子串则输出1,否则输出0,
输入:长度小于9的整数
输出:1或0
方法解析:一开始考虑这道题时大脑短路,老是把长度为2、3、4的子串情况单独考虑,后来才想到只要保证有长度为2的子串相同即可。另外,对于string类型的成员函数substr()参数有些遗忘,这个函数的两个参数分别表示子串的起始位置和子串长度。实现代码如下:
- #include "stdafx.h"
- #include <string>
- #include <iostream>
- using namespace std;
- int fun1(string &s) //方法一:用字符数组来解决
- {
- int i = 0, j;
- int res = 0;
- for (i = 2; i < s.size() - 1; i++)
- {
- for (j = i - 1; j >= 0; j--)
- {
- if (s[i] == s[j] && s[i + 1] == s[j + 1])
- {
- res = 1;
- break;
- }
- }
- if (res == 1)
- break;
- }
- return res;
- }
- int fun2(string &s) //方法二:用string类型的子串来判断
- {
- int flag = 0;
- for (int i = 0; i < s.size()-1; i++)
- {
- for (int j = i + 2; j < s.size()-1; j++)
- {
- if (s.substr(i,2) == s.substr(j,2))
- {
- flag = 1;
- break;
- }
- if (flag)
- break;
- }
- }
- return flag;
- }
- int _tmain(int argc, _TCHAR* argv[])
- {
- string s = "13214121";
- cout <<fun1(s) << endl;
- cout<<fun2(s)<<endl;
- return 0;
- }
2014 华为校招机试题(c/c++开发类)的更多相关文章
- 华为Java机试题
1.程序实现目标: 输入一个字符串,将其各个字符对应的ASCII值加5后,输出结果. 程序要求:该字符串只包含小写字母,若其值加5后的字符值大于'z',将其转换成从a开始的字符. package co ...
- 华为OD机试题
"""最长回文字符串问题"""# 说明:方法很多,这个是最简单,也是最容易理解的一个,利用了动态规化.# 先确定回文串的右边界i,然后以右边 ...
- 优酷土豆2014校园招聘笔试题目之Java开发类
先总体说下题型,共有20道选择题,4道简答题,3道编程题和1道扩展题,题目都比较简单,限时一小时完成. 一.选择题 选择题非常简单,都是基础题,什么死锁发生的条件.HashMap和HashSet查找插 ...
- 2014华为机试西安地区B组试题
2014华为机试西安地区B组试题 题目一.亮着点灯的盏数 一条长廊里依次装有n(1≤n≤65535)盏电灯,从头到尾编号1.2.3.-n-1.n.每盏电灯由一个拉线开关控制.開始,电灯所有关着. 有n ...
- 2014华为机试西安地区A组试题
2014华为机试西安地区A组试题 题目一.分苹果 M个同样苹果放到N个同样篮子里有多少种放法,同意有篮子不放. 1<=M<=10.1<=N<=10 比如5个苹果三个篮子,3,1 ...
- 牛客网华为机试题之Python解法
牛客网华为机试题之Python解法 第1题 字符串最后一个单词的长度 a = input().split(" ") print(len(a[-1])) 第2题 计算字符个数 a = ...
- BAT及各大互联网公司2014前端笔试面试题--Html,Css篇
很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习前端基础更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正 ...
- BAT及各大互联网公司2014前端笔试面试题--JavaScript篇
很多面试题是我自己面试BAT亲身经历碰到的.整理分享出来希望更多的前端er共同进步吧,不仅适用于求职者,对于巩固复习js更是大有裨益. 而更多的题目是我一路以来收集的,也有往年的,答案不确保一定正确, ...
- 面试题2:BAT及各大互联网公司2014前端笔试面试题:HTML/CSS篇
BAT及各大互联网公司2014前端笔试面试题:HTML/CSS篇 Html篇: 1.你做的页面在哪些流览器测试过?这些浏览器的内核分别是什么? IE: trident内核 Firefox:gecko内 ...
随机推荐
- Linux编程_Shell脚本练习题
1,编写shell脚本,计算1~100的和. #! /bin/bash `;do sum=$[$i+$sum] done echo $sum 2,编写shell脚本,输入一个数字n并计算1~n的和. ...
- TPshop标签
很多cms 中有很多 标签, 商品标签 文章标签 列表标签 几十个标签, 让开发者头疼, 难记, TPshop开发者考虑到这点, 用了一个万能标签, 开发者非常方便实用 TPshop万能标签只要 ...
- 详解Paste deploy
原创作品,转载注明本文出处:http://www.cnblogs.com/Security-Darren/p/4087587.html 谈到WSGI,就免不了要了解paste,其中paste depl ...
- 如何找回Ucenter创始人密码,账号无需修改
UCenter 创始人的密码非常重要,忘记或丢失后,就不能进入 UCenter 进行用户和数据的管理,也会对站点造成安全隐患.由于 UCenter 的密码是采用两次 md5 加一个随机数的形式加密的, ...
- 大爱HTML5 9款超炫HTML5最新动画源码
我们分享过很多漂亮的HTML5动画,包括CSS3菜单.HTML5 Canvas动画等.今天我们精选了9款非常不错的超炫HTML5最新动画及其源码,一起来看看. 1.HTML5可爱的404页面动画 很逗 ...
- Objective-c: 移除字符串中的指定字符
string = [[string componentsSeparatedByCharactersInSet:[NSCharacterSet characterSetWithCharactersInS ...
- VOIP NAT穿越之SIP信令穿越
本文原创自 http://blog.csdn.net/voipmaker 转载注明出处. 本文是VOIP通信NAT系列专题的第三篇, 本文论述NAT对SIP协议穿越的影响.SIP协议是基于文本的,而 ...
- 单例模式简介以及C++版本的实现
本篇博文主要内容参考 C++的单例模式一文,在此,为原作者耐心细致的分析讲解,表示感谢.本文将结合此篇文章,给出自己做实验后的理解以及代码,作为今天学习的小结. 单例模式,它的意图是保 ...
- hibernate validate
http://docs.jboss.org/hibernate/validator/4.2/reference/zh-CN/html_single/ --hibernate validate htt ...
- UML的学习
1.什么是UML? 统一建模语言(UML,英语:Unified Modeling Language)是非专利的第三代建模和规约语言.UML是一种开放的方法,用于说明.可视化.构建和编写一个正在开发的. ...