C++笔试强训day20

发布于:2024-05-17 ⋅ 阅读:(141) ⋅ 点赞:(0)

目录

1.经此一役小红所向无敌

2.连续子数组最大和

3.非对称之美


1.经此一役小红所向无敌

链接

简单模拟即可。

需要注意的是:

除完之后有无余数,若有,则还可以再挨一次打。

#include <iostream>
using namespace std;
#define int long long
int a, h, b, k;
signed main() {
	cin >> a >> h >> b >> k;
    
	int sum = 0;
	int cnt1 = h / b;
	int cnt2 = k / a;
	if (h % b != 0)
		cnt1++;
	if (k % a != 0)
		cnt2++;
    
	int cnt = min(cnt1, cnt2);
	sum += cnt * (a + b);
    
	if (cnt1 == cnt2)
		cout << sum << endl;
	else if (cnt1 > cnt2)
	{
		sum += a * 10;
		cout << sum << endl;
	}
	else if (cnt1 < cnt2)
	{
		sum += b * 10;
		cout << sum << endl;
	}
	return 0;
}

2.连续子数组最大和

链接

一道线性dp问题,最主要的是找出dp所表示的含义:

dp[i], 以i为结尾,可以表示的最大数值。

#include <iostream>
using namespace std;

const int N = 2e5 + 10;
int dp[N];
int v[N];
int main() {
    int n;
    cin >> n;

    for(int i = 1; i <= n; ++i)
        cin >> v[i]; 

    for(int i = 1; i <= n; ++i)
        dp[i] = max(dp[i - 1] + v[i], v[i]);

    int ret = -101;
    for(int i = 1; i <= n; ++i)
        ret = max(dp[i], ret);

    cout << ret << endl;
    return 0;
}

填完表后,遍历一遍表中的数,取出最大值即可。

由于,因此可以让 ret 初始化为 -101。 

3.非对称之美

链接

我认为这就是一道数学分析找规律题,暴力强解复杂度太高,易超时,解不出来。

但是这个规律也不好找:

#include <iostream>
#include <string>
using namespace std;
int n;
string s;
int fun()
{
	// 1. 判断是否全都是相同字符
	bool flag = false;
	for (int i = 1; i < n; i++)
	{
		if (s[i] != s[0])
		{
			flag = true;
			break;
		}
	}
	if (flag == false) 
        return 0;
	// 2. 判断本⾝是否是回⽂
	flag = true;
	int left = 0, right = n - 1;
	while (left < right)
	{
		if (s[left] == s[right])
		{
			left++;
			right--;
		}
		else
		{
			flag = false;
			break;
		}
	}

	if (flag) 
        return n - 1;
	else 
        return n;
}
int main()
{
	cin >> s;
	n = s.size();

	cout << fun() << endl;

	return 0;
}

若字符全相同,则返回0。

若从0和n - 1往中间遍历,存在不相同,即可直接break返回 n (个数)。

若全相同,则返回 n - 1。

即这时个对称数,但是如果你取除第一个或最后一个外的所有字符,即可组成非对称。

题目有要求要最大,所以为 n - 1。


网站公告

今日签到

点亮在社区的每一天
去签到