腾讯后台 1 1 0 1 0.1,求第三题思路和第五题题目

第三题想法是排序,然后从最大值平均分两组,如果某一组超过一半,就剩下的给数量少的组,然而一个都没过。。。。。
第五题没看到题目
//第二题
#include "stdafx.h"
#include <string>
#include <vector>
#include <set>
#include <map>
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <sstream>
#include <bitset>
#include <stack>

using namespace std;

bool cmp(pair<int, int> p1, pair<int, int> p2)
{
	if (p1.second <= p2.second)
	{
		return true;
	}
	else
	{
		return false;
	}
}

int main1()
{
	int nNums;
	cin >> nNums;
	vector<pair<int,int>> vecNums;
	int nA, nB;
	while (nNums--)
	{
		cin >> nA >> nB;
		vecNums.push_back(make_pair(nA,nB));
	}
	sort(vecNums.begin(), vecNums.end(),cmp);
	int nMIN = INT_MIN;
	int nCount = vecNums.size() - 1;
	for (size_t i = 0; i <= nCount; )
	{
		--vecNums[i].first;
		--vecNums[nCount].first;
		nMIN = max(vecNums[i].second+vecNums[nCount].second,nMIN);
		if (vecNums[i].first == 0)
		{
			++i;
		}
		if (vecNums[nCount].first == 0)
		{
			--nCount;
		}
	}
	cout << nMIN << endl;
	system("pause");
	return 0;
}
//第四题
// IT笔试.cpp: 定义控制台应用程序的入口点。
//

#include "stdafx.h"
#include <string>
#include <vector>
#include <set>
#include <map>
#include <iostream>
#include <algorithm>
#include <cstdio>
#include <cstdlib>
#include <cmath>
#include <sstream>
#include <bitset>
#include <stack>
#include <limits.h>
using namespace std;

int main()
{
	int n, k;
	int nTem;
	cin >> n >> k;
	vector<int> vecNums;
	while (n--)
	{
		cin >> nTem;
		vecNums.push_back(nTem);
	}
	sort(vecNums.begin(), vecNums.end());
	int i = 0;
	int nMin;
	while (k--)
	{
		if (vecNums[vecNums.size() - 1] != 0)
		{
			while (vecNums[i] == 0)
			{
				++i;
			}
			nMin = vecNums[i];
			cout << nMin << endl;
			for (size_t j = i; j < vecNums.size(); j++)
			{
				vecNums[j] -= nMin;
			}
		}
		else
		{
			cout << 0 << endl;
		}
	}

	system("pause");
    return 0;
}



#腾讯##笔试题目#
全部评论
第三题跟俺思路一毛一样。我也毛都没过
点赞 回复
分享
发布于 2019-09-20 22:34
第五题给出2个数组[1, 2, 3, 4, 5]和[1, 2, 3, 4, 5],他们的所有组合的和,就是sumk = ai + bj,把所有sumk求异或,输出这个异或的值,数组长度最长为20000,数组中的每个数最大为10^9
点赞 回复
分享
发布于 2019-09-20 22:40
联想
校招火热招聘中
官网直投
#include <bits/stdc++.h> #include <thread> #define input freopen("input.txt", "r", stdin) #define output freopen("output.txt", "w", stdout) #define lson l,m,rt<<1 #define rson m+1,r,rt<<1|1 #define random(x) (rand()%x)+1 using namespace std; const int maxn=1e5+5; using LL =long long; const int inf = 0x3f3f3f3f; const int mod=1e6+3; int dp[51][maxn/2]; int main(int argc, char const *argv[]) {     input;output;     int T,n,arr[101],sum;     scanf("%d",&T);     while(T--){         sum=0;         scanf("%d",&n);         assert(n<=100);         for(int i=0;i<n;i++){             scanf("%d",arr+i);             sum+=arr[i];         }         assert(sum<maxn);         for(int i=0;i<=(n+1)/2;i++)             for(int j=0;j<=sum/2;j++)                 dp[i][j]=-inf;         dp[0][0]=0;         for(int i=0;i<n;i++)             for(int j=(n+1)/2;j>0;j--)                 for(int k=sum/2;k>=arr[i];k--)                     dp[j][k]=max(dp[j][k],dp[j-1][k-arr[i]]+arr[i]);         int ans=0;          for(int i=0;i<=sum/2;i++)             ans=max(ans,max(dp[n/2][i],dp[(n+1)/2][i]));         printf("%d %d\n",ans,sum-ans);     }     return 0; } 第三题是背包,问题等价于求n/2或者(n+1)/2个人放入总战斗力和1/2的背包中,看最多能放入多少战斗力,话说求第二题的思路
点赞 回复
分享
发布于 2019-09-20 22:43

相关推荐

点赞 1 评论
分享
牛客网
牛客企业服务