腾讯笔试 记录一下

虽然自己面试已经挂了,但是还是做了一下笔试。前面4题没啥难度的,最后一题是个区间DP。
#include <iostream>
#include <vector>
using namespace std;
int n;
vector<int> num;
void slove() {
	int n = num.size();
	vector<vector<int>> left (n, vector<int>(n, 0)); //向左归并
	vector<vector<int>> right(n, vector<int>(n, 0));  //向右归并
	for (int len = 2; len <= n; len++) {
		for (int i = 0; i + len - 1 < n; i++) {
			int j = i + len - 1;
			int tmp_left = num[i], tmp_right = num[j];
			left[i][j] = min(left[i + 1][j] + abs(tmp_left - num[i + 1]), right[i + 1][j] + abs(tmp_left - num[j]));
			right[i][j] = min(right[i][j-1] + abs(tmp_right - num[j-1]), left[i][j-1] + abs(tmp_right - num[i]));
		}
	}
	cout << min(left[0][n - 1], right[0][n - 1]) << endl;
}
int main() {
	int t;
	cin >> n;
	while (n--) {
		cin >> t;
		num.push_back(t);
	}
	slove();
	return 0;
}

第四题:
//k=str.size()-n; k代表需要删除字母的个数
//解题思路 贪心
string slove(string str, int k) {  
	if (str.size() <= k) return "";
	string res;
	int count = 0;
	for (int i = 0; i < str.size(); i++) {
		if (res.size() == 0) res += str[i];
		else if (res.back() < str[i] && count < k) {
			while (res.back() < str[i] && count < k) {
				count++; res.pop_back();
			}
			 res += str[i];
		}
		else res += str[i];
	}
	while (count < k) res.pop_back(),count++;
	return res;
}


#腾讯笔试##腾讯##笔试题目#
全部评论
大佬,求第四题 谢谢
点赞 回复 分享
发布于 2021-08-22 22:16
求个第五题!!!大佬
点赞 回复 分享
发布于 2021-08-22 23:06
怎么知道自己面试挂了呀,我二面后没结果了
点赞 回复 分享
发布于 2021-08-23 00:50

相关推荐

预计下个星期就能开奖吧,哪位老哥来给个准信
华孝子爱信等:对接人上周说的是这周
点赞 评论 收藏
分享
牛客963010790号:为什么还要收藏
点赞 评论 收藏
分享
菜菜咪:1. 可以使用简历网站的模版,美观度会更好一点 2. 邮箱可以重新申请一个,或者用qq邮箱的别名,部分hr可能会不喜欢数字邮箱 3. 项目经历最好分点描述,类似的项目很多,可以参考一下别人怎么写的 4. 自我评价可加可不加,技术岗更看重技术。最后,加油,优秀士兵
点赞 评论 收藏
分享
3 6 评论
分享
牛客网
牛客企业服务