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

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


/*
卢卡斯的驱逐者大军已经来到了赫柏的卡诺萨城,赫柏终于下定决心,集结了大军,与驱逐者全面开战。
卢卡斯的手下有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中的一个数字。


输出描述:
输出一个整数,代表分配方案数

输入例子:
2
01 23
2
01 01
3
3 015 5

输出例子:
4
2
2
*/

#pragma warning(disable:4996)//屏蔽警告 
#include 
#include 
#include 
#include 
using namespace std;
vector 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;
		}
		else
			continue;
		
	}
	
	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');
				else
					break;
			}
			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 100
23 100

输出例子:
0
1
*/
#pragma warning(disable:4996)//屏蔽警告 
#include 
#include 
#include 
#include 
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。


输出描述:
输出一个整数,代表受到禁忌雷炎伤害的敌人数量。

输入例子:
25
3

输出例子:
12
0
*/
#pragma warning(disable:4996)//屏蔽警告 
#include 
#include 

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;
					else
						ans += 8;
					break;
				}
				else if (sum > s)/*此时(x,y)在圆外,提早退出*/
					break;
			}
		}
		printf("%d\n", ans);
	}
}


你可能感兴趣的:(水题)