当前位置: 首页 > article >正文

【C++笔试强训】如何成为算法糕手Day3


db43723fcefb47a09b575a7812877e29.png


 学习编程就得循环渐进,扎实基础,勿在浮沙筑高台  

 循环渐进Forward-CSDN博客


目录

 循环渐进Forward-CSDN博客

第一题:除2!

第二题:dd爱框框

第三题:简写单词


第一题:除2!

牛客网做题链接:除2! (nowcoder.com)

 思路:模拟+贪心+优先队列

        利用优先队列将最大数当作大根,每次将最大的数进行判断,使其满足次数不超过k次。

本题能用贪心是因为每一部最优解都能成为全局的最优解。

//除2!

typedef long long ll;

ll n, k;
priority_queue <ll>q;

int main()
{
	cin >> n >> k;
	ll sum = 0, x;
	while (n--)
	{
		cin >> x;
		sum += x;
		if (x % 2 == 0)
		{
			q.push(x);
		}
	}

	while (q.size() && k--)
	{
		ll t = q.top() / 2;
		q.pop();
		sum -= t;
		if (t % 2 == 0)
		{
			q.push(t);
		}

	}
	cout << sum;

	return 0;
}

第二题:dd爱框框

牛客网做题链接:F-dd爱框框_牛客小白月赛34 (nowcoder.com)

思路:本题有两种解法,一是暴力循环解法,但是时间复杂度会爆炸因此不建议用。二是滑动窗口法。我使用滑动窗口(同向双指针)法解本题。

        首先分为四个步骤,一进窗口,二判断值是否满足,三更新结果,四出窗口。

一:设置right右指针先进行移动,配合left左指针进行窗口判断。

二:利用sum数组判断数组内数值是否超过n。

三:当left+right长度小于retlen长度时更新结果

四:sum-=left出窗口

//dd爱框框

const int N = 1e7 + 10;//防止后续数组越界

int arr[N];
int n, x;

int main()
{
	cin >> n >> x;
	for (int i = 1; i <= n; i++)
	{
		cin>>arr[i];
	}

	int left = 0, right = 0,sum=0;
	int retLen=N, retLeft=-1, retRight=-1;

	while (right <= n)
	{
		sum += arr[right];
		while (sum >= x)
		{
			if (retLeft + retRight + 1 < retLen)
			{
				retLeft = left;
				retRight = right;
				retLen = retRight - retLeft + 1;
			}
			sum -= arr[left];
		}
	}
	cout << retLeft << "" << retRight << endl;
	return 0;
}

第三题:简写单词

牛客网做题链接:简写单词_牛客题霸_牛客网 (nowcoder.com)

思路:这题属实是简单,简单模拟题考察的是对代码的掌握能力。

//简写单词
int main()
{
	string s;

	while (cin >> s)
	{
		if (s[0] >= 'a' && s[0] <= 'z')
		{
			cout << (char)s[0] - 32;
		}
		else {
			cout << s[0];
		}
	}


	return 0;
}

 学习编程就得循环渐进,扎实基础,勿在浮沙筑高台



http://www.kler.cn/a/320235.html

相关文章:

  • 记录———封装uni-app+vant(u-upload)上传图片组件
  • MySQL8 安装教程
  • 【大语言模型】ACL2024论文-12 大型语言模型的能力如何受到监督式微调数据组成影响
  • NIST 发布后量子密码学转型战略草案
  • 如何创建一个项目用于研究element-plus的原理
  • More Effective C++ Item 7:区别使用()和{}创建对象
  • Linux标准I/O
  • (11)(2.1.2) DShot ESCs(四)
  • 学校快递站点管理|基于springboot学校快递站点管理设计与实现(源码+数据库+文档)
  • 屠龙之人终成恶龙
  • 页面禁用鼠标右键属于反爬虫措施吗 ?
  • 《飞机大战游戏》实训项目(Java GUI实现)(设计模式)(简易)
  • L2 Loss介绍及梯度计算说明
  • 2、.Net 前端框架:Blazor - .Net宣传系列文章
  • OJ在线评测系统 后端开发数据库初始化工作 开发库表 建立数据库索引 Mybatis映射初始化接口开发
  • 自动驾驶系列—盲点检测(BSD)功能:智能驾驶安全的关键保障
  • 14年数据结构
  • oracle direct path read处理过程
  • 接口调用工具-HttpClient,HttpUtil,RestTemplate
  • Spring Security - 用户授权
  • 1数据结构与算法-前言
  • OpenCV图像文件读写(3)统计多页图像文件中的页面数量函数imcount()的使用
  • 机器学习中的元强化学习
  • Fusion Access
  • 聚焦Llama新场景和AR眼镜,扎克伯格用AI赋能元宇宙,Meta Connect 2024开发者大会直播约起...
  • linux创建固定大小的文件夹用于测试