阿里 8.16笔试 C++参考答案

1.编译器求大小问题
#include<iostream>
#include<vector>
#include<algorithm>
#include <cassert>
#include<sstream>
#include <stack>
using namespace std;
bool check(string& str)
{
	for (char c : str)
	{
		if (c == '[')
			return true;
	}
	return false;
}

int main()
{
	string s;
	getline(cin, s);
	stringstream ss(s);
	string temp;
	int cnt = 0;
	int mod = 1;
	int z = 0;
	while (getline(ss, temp, ' '))
	{
		if (mod)
		{
			if (temp == "int")
				z = 4;
			else if (temp == "char")
				z = 1;
			else if (temp == "long")
				z = 8;
			mod = 0;
			continue;
		}
		stringstream ss2(temp);
		string temp2;
		while (getline(ss2, temp2, ','))
		{
			if (check(temp2))
			{
				stack<char> st;
				vector<int> vec;
				int i, j;
				int num = 1, n = temp2.size();
				for (int k = 0; k < n; k++)
				{
					if (temp2[k] == '[')
					{
						i = k + 1;
					}
					else if (temp2[k] == ']')
					{
						j = k - 1;
						string str = temp2.substr(i, j - i + 1);
						vec.push_back(atoi(str.c_str()));
					}
				}
				for (int x : vec)
					num *= x;
				cnt += num * z;
			}
			else
			{
				cnt += z;
			}
		}
	}
	cout << cnt << endl;
}

2.联盟问题,并查集解法

#include<iostream>
#include<vector>
#include<algorithm>
#include <cassert>
#include<sstream>
#include <stack>
#include<unordered_map>
using namespace std;
unordered_map<int, int> mp;
vector<int> vec;
int find(vector<int>& dp, int x)
{
	while (dp[x] != x)
	{
		x = dp[x];
	}
	return dp[x];
}
bool check(vector<int>& dp, int a, int b)
{
	int x = find(dp, a);
	int y = find(dp, b);
	if (x == y)
		return true;
	else
		return false;
}
int func(vector<int>& dp, int a, int b)
{
	int x = find(dp, a);
	int y = find(dp, b);
	if (x == y)
		return -1;
	else
	{
		int num = (x + y) ^ (abs(vec[x] - vec[y]));
		if (x < y)
		{
			dp[y] = x;
			vec[x] = vec[x] + vec[y];
		}
		else
		{
			dp[x] = y;
			vec[y] = vec[x] + vec[y];
		}
		return num;
	}
}

int main()
{
	int n, m;
	cin >> n >> m;
	int cnt = n;
	vec = vector<int>(n + 1);
	vector<int> dp(n + 1);
	for (int i = 0; i < n + 1; i++)
		dp[i] = i;
	int id = 1;
	int x;
	while (cnt--)
	{
		cin >> x;
		vec[id++] = x;
	}
	cnt = m;
	int a, b, t, q;
	while (cnt--)
	{
		cin >> t >> a >> b;
		if (t == 1)
		{
			q = func(dp, a, b);
			if (q != -1)
				cout << q << endl;
		}
		else
		{
			if (check(dp, a, b))
				cout << "YES" << endl;
			else
				cout << "NO" << endl;
		}
	}
	return 0;
}


#阿里笔试##笔经##阿里巴巴#
全部评论
大佬  有题干吗
点赞 回复 分享
发布于 2021-08-17 11:34

相关推荐

再挂就要开播了😭:活不了了,一打开就看到这么厉害的
点赞 评论 收藏
分享
已经烂了:算法去制造业最少也要211,双非搞算法就是死路一条。至少我在的部门,算法工程师最低都是211毕业的,而且岗位极少。
点赞 评论 收藏
分享
评论
1
5
分享

创作者周榜

更多
牛客网
牛客企业服务