乐视2017暑期实习生笔试题(一)

来源:互联网 发布:sql 将竖列字段拼接 编辑:程序博客网 时间:2024/06/06 09:21

最近为应对秋招,又开始刷题,乐视的三大编程题,题目真心长


/*卢卡斯的驱逐者大军已经来到了赫柏的卡诺萨城,赫柏终于下定决心,集结了大军,与驱逐者全面开战。卢卡斯的手下有6名天之驱逐者,这6名天之驱逐者各赋异能,是卢卡斯的主力。为了击败卢卡斯,赫柏必须好好考虑如何安排自己的狂战士前去迎战。狂战士的魔法与一些天之驱逐者的魔法属性是相克的,第i名狂战士的魔法可以克制的天之驱逐者的集合为Si(Si中的每个元素属于[0,5])。为了公平,两名狂战士不能攻击同一个天之驱逐者。现在赫柏需要知道共有多少种分派方案。例:S1={01},S2={23},代表编号为0的狂战士的魔法可以克制编号为0和编号为1的天之驱逐者,编号为1的狂战士的魔法可以克制编号为2和编号为3的天之驱逐者,共有四种方案:02,03,12,13。02---代表第一个狂战士负责编号为0的驱逐者,第二个狂战士负责编号为2的驱逐者;03---代表第一个狂战士负责编号为0的驱逐者,第二个狂战士负责编号为3的驱逐者;12---代表第一个狂战士负责编号为1的驱逐者,第二个狂战士负责编号为2的驱逐者;13---代表第一个狂战士负责编号为1的驱逐者,第二个狂战士负责编号为3的驱逐者;S1={01},S2={01},代表编号为0的狂战士的魔法可以克制编号为0和编号为1的天之驱逐者,编号为1的狂战士的魔法可以克制编号为0和编号为1的天之驱逐者,共有两种方案:01,10。输入描述:多组测试数据,请处理到文件结束。对于每组测试数据:第一行为一个整数N,代表狂战士的数量。第二行为N个字符串,第i个字符串表示第i个狂战士能够克制的天之驱逐者的集合。保证:1<=N<=6,1<=每个字符串的长度<=6,且每个字符都是0~5中的一个数字。输出描述:输出一个整数,代表分配方案数输入例子:201 23201 0133 015 5输出例子:422*/#pragma warning(disable:4996)//屏蔽警告 #include <iostream>#include <string>#include <vector>#include <string.h>using namespace std;vector<int> datasets[10];bool selected[10];int solution(int start,int end){if (start >= end)return 1;int ans = 0;int t = datasets[start].size();for (int i = 0; i < t; i++){int num = datasets[start][i];if (selected[num] == false){selected[num] = true;ans += solution(start + 1, end);selected[num] = false;}elsecontinue;}return ans;}int main(){int n;while(scanf("%d\n", &n)!=EOF){memset(selected, false, sizeof(selected));char str[50];cin.getline(str, 50, '\n');int k = -1;int sum = 1;for (int i = 0; i < n; i++){while (str[++k]){if (str[k] >= '0'&&str[k] <= '9')datasets[i].push_back(str[k]-'0');elsebreak;}sum *= datasets[i].size();}printf("%d\n", solution(0, n));for (int i = 0; i < n; i++)datasets[i].clear();}return 0;}



/*在最近几场魔兽争霸赛中,赫柏对自己的表现都不满意。为了尽快提升战力,赫柏来到了雷鸣交易行并找到了幻兽师格丽,打算让格丽为自己的七阶幻兽升星。经过漫长的等待以后,幻兽顺利升到了满星,赫柏很满意,打算给格丽一些小费。赫柏给小费是有原则的:1.最终给格丽的钱必须是5的倍数;2.小费必须占最终支付费用的5%~10%之间(包含边界)。升星总共耗费A魔卡,赫柏身上带了B魔卡,赫柏想知道他有多少种支付方案可供选择。注:魔卡是一种货币单位,最终支付费用=本该支付的+小费输入描述:多组测试数据,请处理到文件结束。对于每组测试数据:包含两个整数A和B。保证:1<=A,B<=2,000,000,000,A<=B。输出描述:输出一个整数,代表方案数。输入例子:4 10023 100输出例子:01*/#pragma warning(disable:4996)//屏蔽警告 #include <iostream>#include <string>#include <vector>#include <string.h>using namespace std;int main(){unsigned int a, b;while (scanf("%d%d", &a, &b) != EOF){unsigned int ans = 0;unsigned int low = a / 0.95 + ((a / 0.95 - (unsigned int)(a / 0.95)) == 0 ? 0 : 1);unsigned int high = a / 0.9;unsigned int start = (low / 5 + (low % 5 == 0 ? 0 : 1)) * 5;for (unsigned int i = start; i <= high&&i<=b; i+=5){++ans;}printf("%d\n", ans);}}


/*[编程题] 禁忌雷炎赫柏在绝域之门击败鲁卡斯后,从鲁卡斯身上掉落了一本高级技能书,赫柏打开后惊喜地发现这是一个早已失传的上古技能---禁忌雷炎。该技能每次发动只需扣很少的精神值,而且输出也非常高。具体魔法描述如下:把地图抽象为一个二维坐标,技能发动者位于(0,0)位置。以技能发动者为中心,做一个半径为r的圆,满足r^2=S,如果敌人位于这个圆上,且位置为整点坐标,这个敌人将收到该技能的输出伤害。。更厉害的是,禁忌雷炎可以通过改变魔法输入来控制S的大小,因此数学好的魔法师可以通过该技能攻击到更多的敌人。赫柏想将这个技能学会并成为自己的主技能,可数学是他的硬伤,所以他请求你为他写一个程序,帮帮他吧,没准他就把禁忌雷炎与你分享了 : )输入描述:多组测试数据,请处理到文件结束。对于每组测试数据,只包含一个整数S。保证:1<=S<=2,000,000,000。输出描述:输出一个整数,代表受到禁忌雷炎伤害的敌人数量。输入例子:253输出例子:120*/#pragma warning(disable:4996)//屏蔽警告 #include <iostream>#include <algorithm>int main(){unsigned int s;while (scanf("%d", &s) != EOF){unsigned int ans = 0;float max = sqrt(s);unsigned int x = (unsigned int)max;unsigned int y = 0;/*关于直线y = x对称的情况*/unsigned int xmax = (unsigned int)max / 2;for( ; x > xmax; x--){for (; y <= x; y++)//此处其实不用内循环,只是图逻辑清晰{unsigned int sum = x*x + y*y;if (sum == s){/*点在直线y = x上或y=0上的情况*/if (x == y || y == 0)ans += 4;elseans += 8;break;}else if (sum > s)/*此时(x,y)在圆外,提早退出*/break;}}printf("%d\n", ans);}}


0 0
原创粉丝点击