[网易]2018校园招聘编程题真题集合
2017-09-16 23:09
453 查看
Andrew Zhang
Sep 16, 2017
题目:
小易准备去魔法王国采购魔法神器,购买魔法神器需要使用魔法币,但是小易现在一枚魔法币都没有,但是小易有两台魔法机器可以通过投入x(x可以为0)个魔法币产生更多的魔法币。
魔法机器1:如果投入x个魔法币,魔法机器会将其变为2x+1个魔法币
魔法机器2:如果投入x个魔法币,魔法机器会将其变为2x+2个魔法币
小易采购魔法神器总共需要n个魔法币,所以小易只能通过两台魔法机器产生恰好n个魔法币,小易需要你帮他设计一个投入方案使他最后恰好拥有n个魔法币。
参考答案:
题目:
为了得到一个数的”相反数”,我们将这个数的数字顺序颠倒,然后再加上原先的数得到”相反数”。例如,为了得到1325的”相反数”,首先我们将该数的数字顺序颠倒,我们得到5231,之后再加上原先的数,我们得到5231+1325=6556.如果颠倒之后的数字有前缀零,前缀零将会被忽略。例如n = 100, 颠倒之后是1.
参考代码:
题目:
一个由小写字母组成的字符串可以看成一些同一字母的最大碎片组成的。例如,”aaabbaaac”是由下面碎片组成的:’aaa’,’bb’,’c’。牛牛现在给定一个字符串,请你帮助计算这个字符串的所有碎片的平均长度是多少。
参考代码:
题目:
小易有一个长度为N的正整数数列A = {A[1], A[2], A[3]…, A
}。
牛博士给小易出了一个难题:
对数列A进行重新排列,使数列A满足所有的A[i] * A[i + 1](1 ≤ i ≤ N - 1)都是4的倍数。
小易现在需要判断一个数列是否可以重排之后满足牛博士的要求。
参考代码:
Sep 16, 2017
题目:
小易准备去魔法王国采购魔法神器,购买魔法神器需要使用魔法币,但是小易现在一枚魔法币都没有,但是小易有两台魔法机器可以通过投入x(x可以为0)个魔法币产生更多的魔法币。
魔法机器1:如果投入x个魔法币,魔法机器会将其变为2x+1个魔法币
魔法机器2:如果投入x个魔法币,魔法机器会将其变为2x+2个魔法币
小易采购魔法神器总共需要n个魔法币,所以小易只能通过两台魔法机器产生恰好n个魔法币,小易需要你帮他设计一个投入方案使他最后恰好拥有n个魔法币。
参考答案:
#include <iostream> #include <string> using namespace std; int main() { int n; cin >> n; int start = 0, end = 0; while (end < n) { start = 2 * start + 1; end = 2 * end + 2; } while (true) { int middle = (start + end) / 2; if (n <= middle) { cout << '1'; end = middle; } else { cout << '2'; start = middle + 1; } if (start == end) break; } cout << endl; return 0; }
题目:
为了得到一个数的”相反数”,我们将这个数的数字顺序颠倒,然后再加上原先的数得到”相反数”。例如,为了得到1325的”相反数”,首先我们将该数的数字顺序颠倒,我们得到5231,之后再加上原先的数,我们得到5231+1325=6556.如果颠倒之后的数字有前缀零,前缀零将会被忽略。例如n = 100, 颠倒之后是1.
参考代码:
#include <iostream> using namespace std; int func(int n) { int temp = n; int len = 0; int pow = 1; while (temp > 0) { len++; pow *= 10; temp /= 10; } temp = n; for (int i = 0; i < len; i++) { pow /= 10; n += (temp % 10)*pow; temp /= 10; } return n; } int main() { int n; cin >> n; cout << func(n) << endl; return 0; }
题目:
一个由小写字母组成的字符串可以看成一些同一字母的最大碎片组成的。例如,”aaabbaaac”是由下面碎片组成的:’aaa’,’bb’,’c’。牛牛现在给定一个字符串,请你帮助计算这个字符串的所有碎片的平均长度是多少。
参考代码:
#include <iostream> #include <string> #include <iomanip> using namespace std; int main() { int count = 0; int len = 0; int start = 0; int i; string s; cin >> s; for (i = 1; i < s.length(); i++) { if (s[i] != s[start]) { count++; len += i - start; start = i; } } if (s[i - 1] == s[start]) { count++; len += i - start; } else { count++; len += 1; } cout << fixed << setprecision(2) << 1.0 * len / count << endl; return 0; }
题目:
小易有一个长度为N的正整数数列A = {A[1], A[2], A[3]…, A
}。
牛博士给小易出了一个难题:
对数列A进行重新排列,使数列A满足所有的A[i] * A[i + 1](1 ≤ i ≤ N - 1)都是4的倍数。
小易现在需要判断一个数列是否可以重排之后满足牛博士的要求。
参考代码:
#include <iostream> #include <vector> using namespace std; int main() { int t; cin >> t; while (t--) { vector<vector<int>> state(3, vector<int>(0)); int n; cin >> n; for (int i = 0; i < n; i++) { int temp; cin >> temp; if ((temp & 3) == 0) { state[2].push_back(temp); } else if ((temp & 1) == 0) { state[1].push_back(temp); } else { state[0].push_back(temp); } } if (state[2].size() >= state[0].size()) { cout << "Yes" << endl; } else if (state[2].size() == state[0].size() - 1) { if (state[1].size() == 0) { cout << "Yes" << endl; } else { cout << "No" << endl; } } else { cout << "No" << endl; } } return 0; }
相关文章推荐
- [网易]2018校园招聘编程题真题集合
- 网易2018校园招聘编程题真题集合
- 网易2018校园招聘编程题真题集合1魔法币
- 网易2018校园招聘编程题真题集合
- 网易2018校园招聘编程题真题集合 (部分)
- 网易2018校园招聘编程题真题集合2相反数
- 牛客网-网易2018校园招聘编程题真题集合-解题思路及源码
- 网易2018校园招聘编程题真题集合3字符串碎片
- 网易2018校园招聘编程题真题集合(一)
- 网易2018校园招聘编程题真题集合之重排序列
- 网易2018校园招聘编程题真题-[编程题] 字符串碎片
- 网易2018校园招聘编程题真题-[编程题] 相反数
- 网易2018校园招聘编程题真题 合唱
- 网易2018校园招聘编程题真题-[编程题] 交错01串
- 网易2018校园招聘编程题真题-[编程题] 魔法币
- 《面试编程题真题合集(一)——网易2018校园招聘真题题解》
- 网易2018校园招聘编程真题之重排数列
- 网易2018年校园招聘编程题真题(魔法币&&相反数&&字符串碎片&&重排数列)
- 网易2018校园招聘编程真题之魔法币
- 网易2018校园招聘编程题