第十四届蓝桥杯大赛软件赛省赛(C/C++ 大学B组)题解

news2024/11/23 10:53:58

 尝试再做一次,我记得还是有点难,我会尽量多写一点解析,尽量让基础比较弱的友友也能看懂,希望能给你带来帮助

目录

1. 日期统计

题目描述

解题思路

具体代码

2. 01 串的熵

题目描述

解题思路

具体代码

3. 冶炼金属

题目描述

解题思路

具体代码

4. 飞机降落

题目描述

解题思路

具体代码

5. 接龙数列

题目描述

解题思路

具体代码

6. 岛屿个数(待写)

题目描述

解题思路

具体代码

7. 子串简写

题目描述

解题思路

具体代码

8. 整数删除(待写)

题目描述 

解题思路

具体代码

1. 日期统计

题目描述

小蓝现在有一个长度为 100 的数组,数组中的每个元素的值都在 0 到 9 的

范围之内。数组中的元素从左至右如下所示:

5 6 8 6 9 1 6 1 2 4 9 1 9 8 2 3 6 4 7 7 5 9 5 0 3 8 7 5 8 1 5 8 6 1 8 3 0 3 7 9 2 7 0 5 8 8 5 7 0 9 9 1 9 4 4 6 8 6 3 3 8 5 1 6 3 4 6 7 0 7 8 2 7 6 8 9 5 6 5 6 1 4 0 1 0 0 9 4 8 0 9 1 2 8 5 0 2 5 3 3

 现在他想要从这个数组中寻找一些满足以下条件的子序列:
1. 子序列的长度为 8 ;
2. 这个子序列可以按照下标顺序组成一个 yyyymmdd 格式的日期,并且
要求这个日期是 2023 年中的某一天的日期,例如 20230902 , 20231223 。
yyyy 表示年份, mm 表示月份, dd 表示天数,当月份或者天数的长度只
有一位时需要一个前导零补充。
请你帮小蓝计算下按上述条件一共能找到多少个 不同 的 2023 年的日期。
对于相同的日期你只需要统计一次即可。

解题思路

这道题在赛场上大家可能和我一样,脑子里面第一想法就是循环遍历,反正就8次,我也是这么做的,后面我的老师给我介绍了另一种解法,我都写一下

方法一

直接简单粗暴地循环,唯一需要注意的是记得筛出重复的日期,我用的set(不太清楚set用法的友友需要自己查一下哦),自动帮我去重,我将每次符合条件的日期(一个八位数的数字)insert到set容器中,后面循环结束后,set的长度就是满足要求的日期的个数(具体代码在下面)

方法二:

这是老师赛后告诉我的,我看见网上也有很多这样写的。不需要循环原本的数组,而是循环遍历2023年的每一天,看看这一天年-月-日这八个数字是否在原数据中也顺序出现,这种解法就不要考虑有相同日期的情况(我文字描述不太清楚,可以直接看下面的代码,看了就知道)

具体代码

方法一代码

这个代码看起来很长,其实很简单(思路见上),就是八重循环,但是需要仔细再仔细,代码里面我也有写注释,可以看看,不难

 // 长度为8 2023 01 24 
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 3e5+ 24 , M = 1e9 + 24 , n = 100;
// 原数据 
int m[100] = {5 ,6 ,8 ,6 ,9 ,1 ,6 ,1 ,2 ,4 ,9 ,1 ,9 ,8 ,2 ,3 ,6 ,4 ,7 ,7 ,5 ,9 ,5 ,0 ,3 ,8 ,7 ,5 ,8 ,
		   1 ,5 ,8 ,6 ,1 ,8 ,3 ,0 ,3 ,7 ,9 ,2 ,7 ,0 ,5 ,8 ,8 ,5 ,7 ,0 ,9 ,9 ,1 ,9 ,4 ,4 ,6 ,8 ,6 ,
		   3 ,3 ,8 ,5 ,1 ,6 ,3 ,4 ,6 ,7 ,0 ,7 ,8 ,2 ,7 ,6 ,8 ,9 ,5 ,6 ,5 ,6 ,1 ,4 ,0 ,1, 0 ,0 ,9 ,
		   4 ,8 ,0 ,9 ,1 ,2 ,8 ,5 ,0 ,2 ,5 ,3 ,3};
// 存每月有多少天 
int D[] = {0 , 31 , 28 , 31 , 30 , 31, 30 , 31 , 31 , 30 , 31 , 30 , 31};  
set<int> s; //用set记录满足要求的日期(数字),自动会去重,这样set中数字的个数就是答案 
int main()
{
	int a , b , c , d , e , f , j , h , day , month , date;
//	  1、确保前面4个数字是 2023   abcd
	for(a = 0 ; a < n ; a ++)
	{
		if(m[a] == 2)  // 2
		{
			for(b = a+1 ; b < n ; b ++)
			{
				if(m[b] == 0)  // 0
				{
					for(c = b+1 ; c < n ; c ++)
					{
						if(m[c] == 2)  // 2
						{
							for(d = c+1 ; d < n ; d ++)
							{
								if(m[d] == 3)  // 3
								{
//									2、保证后面四位  月-日符合逻辑   efjh
									for(e = d+1 ; e < n ; e ++)
									{
										for(f = e+1 ; f < n ; f ++)
										{
//											几月??  满足month在1-12 
											month = m[e]*10 + m[f];
											if(month >= 1 && month <= 12)
											{
		 										for(j = f+1 ; j < n ; j ++)
		 										{
		 											for(h = j+1 ; h < n ; h ++)
		 											{
//														几日??  满足day在1-D[month]对应月的日期内 
		 												day = m[j]*10 + m[h];
		 												if(day >= 1 && day <= D[month])
		 												{
		 													date = 2023*10000 + month*100 + day;
		 													s.insert(date);
														}
													}
												}
											}
										}
									}
								}
							}
						}
					}
				}
			} 
		}
	}
	cout << s.size();
	return 0 ; 
}

方法二代码

代码里面的注释写的比较详细可以看看

// 方法二 
 // 长度为8 2023 01 24 
#include <iostream>
#include <algorithm>
#include <cmath>
using namespace std;
typedef long long ll;
const int N = 3e5+ 24 , M = 1e9 + 24 , n = 100;
// 原数据 
int m[100] = {5, 6, 8, 6, 9, 1, 6, 1, 2, 4, 9, 1, 9, 8, 2, 3, 6, 4, 7, 7, 5, 9, 5, 0, 3, 8, 7, 5, 8, 1, 5,
              8, 6, 1, 8, 3, 0, 3, 7, 9, 2, 7, 0, 5, 8, 8, 5, 7, 0, 9, 9, 1, 9, 4, 4, 6, 8, 6, 3, 3, 8, 5,
              1, 6, 3, 4, 6, 7, 0, 7, 8, 2, 7, 6, 8, 9, 5, 6, 5, 6, 1, 4, 0, 1, 0, 0, 9, 4, 8, 0, 9, 1, 2,
              8, 5, 0, 2, 5, 3, 3};
// 存每月有多少天 
int D[] = {0, 31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};  
int main()
{
	int month, day, i, j, ans = 0 ;
	
//	遍历2023年的12个月 
	for(month = 1 ; month <= 12 ; month ++)
	{		
//		遍历每一天 
		for(day = 1 ; day <= D[month] ; day ++)
		{
			string str = "2023";
			if(month < 10)  str += "0";  //月份只有一位数需要0填充 
//			to_string将数字类型的变量转换为对应的字符串表示
			str += to_string(month);
			if(day < 10)  str += "0";  //天数只有一位数需要0填充 
			str += to_string(day);
//			判断现在的str(这是一个8位数字组成的字符串,表示一个日期) 
//			判断字符串的8个字符是否在原数据m[]中存在,按照顺序

//			i是原数据m[]的索引,j是str的索引, 
			for(i = 0 , j = 0 ; i < n && j < 8 ; i ++)
			{
				if(m[i] == str[j] - '0')  //如果str[j]这个这个数字在m[中存在] 
				{
					j ++;  // j索引后移,用于判断下一个 
				}
			} 
			if(j >= 8)  ans ++;
		} 
	}
	cout << ans ;
	return 0 ;
}

2. 01 串的熵

题目描述

(文字复制过来格式有误,采用截图,请见谅)

解题思路

我的解法也比较没有技术含量,根据题意:

我们假设0出现了x次,1出现了23333333-x次
可以发现H(S)的值就是等于

带入公式中之后将x从0~23333333遍历,
如果答案大于23333333/2,记得把答案更新为23333333-ans,因为0出现的次数小于1的次数。

考试的时候我想的是根据公式推导出x的值,但是实在是不好算,就另辟蹊径,直接粗暴的遍历【怪不得大家又称蓝桥杯为暴力杯哈哈】

答案:11027421 

具体代码
#include <bits/stdc++.h> 
using namespace std;
typedef long long ll;
const int N = 3e5+ 24 , M = 1e9 + 24 ;

int n = 23333333;
double Hs = 11625907.5798;
int main()
{
//	cout << log2(4);
	int x , ans ;
	double temp;
	for(x = 0 ; x <= n ; x ++)
	{
		double temp = -x*1.0/n*log2(x*1.0/n)*x - (n-x)*1.0/n*log2((n-x)*1.0/n)*(n-x);
        if(abs(temp - Hs) <= 0.0001){
            if(x > n/2)  ans = n - x;
			else  ans = x;
			break;
        }
	}
	cout << ans ;
	return 0 ;
}

// 答案:11027421 

3. 冶炼金属

题目描述

【问题描述】

小蓝有一个神奇的炉子用于将普通金属 O 冶炼成为一种特殊金属 X。这个 炉子有一个称作转换率的属性 V,V 是一个正整数,这意味着消耗 V 个普通金 属 O 恰好可以冶炼出一个特殊金属 X,当普通金属 O 的数目不足 V 时,无法 继续冶炼。 现在给出了 N 条冶炼记录,每条记录中包含两个整数 A 和 B,这表示本次 投入了 A 个普通金属 O,最终冶炼出了 B 个特殊金属 X。每条记录都是独立 的,这意味着上一次没消耗完的普通金属 O 不会累加到下一次的冶炼当中。 根据这 N 条冶炼记录,请你推测出转换率 V 的最小值和最大值分别可能是 多少,题目保证评测数据不存在无解的情况。

【输入格式】

第一行一个整数 N,表示冶炼记录的数目。 接下来输入 N 行,每行两个整数 A、B,含义如题目所述。

【输出格式】

   输出两个整数,分别表示 V 可能的最小值和最大值,中间用空格分开。

【样例输入】

3

75  3

53  2

59  2

【样例输出】

20  25

【样例说明】

当 V = 20 时,有:⌊ 75/ 20 ⌋ = 3,⌊ 53/ 20 ⌋ = 2,⌊ 59/ 20 ⌋ = 2,可以看到符合所有冶炼 记录。

  当 V = 25 时,有:⌊ 75 /25 ⌋ = 3,⌊ 53/ 25 ⌋ = 2,⌊ 59/ 25 ⌋ = 2,可以看到符合所有冶炼记录。

且再也找不到比 20 更小或者比 25 更大的符合条件的 V 值了。

【评测用例规模与约定】

对于 30% 的评测用例,1 ≤ N ≤ 10^2。

对于 60% 的评测用例,1 ≤ N ≤ 10^3。

对于 100% 的评测用例,1 ≤ N ≤ 10^4,1 ≤ B ≤ A ≤ 10^9。

解题思路

题目的意思还是挺好理解的,主要在V的最大值和最小值,其实是一个求交集的过程,只有交集才能满足每一个数据的要求,也就是右边界要取所有右边界的最小值(每组数据求出来的最大值中的最小值),左边界同理,需要所有求出来的左边界的最大值(每组数据求出来的最小值中的最大值),这个还是挺好理解的,如果实在不太理解,建议用样例验证一下,比较容易

现在我们来看看,怎么求每组数据对应的最大值与最小值:

最大值:这个比较简单,我们知道投入了 a 个普通金属 O,最终冶炼出了 b 个特殊金属 X,那么V的最大值就是a/b,没有比这个还大的值了

最小值:假设最小值为vmin,那么肯定存在a/vmin = b ,a/vmin取的是整数,因为vmin是金属O转换成X的转换率最小值,如果vmin减小一个单位,那么肯定b的值会增加一个单位,能理解吗,就是本来a/vmin就能冶炼出b个X,而vmin是冶炼出b个X的最小值,如果vmin减少,肯定b会增加,所以我们可得:a/(vmin-1) = b+1,那么,vmin = a/(b+1)+1

我的表达能力不太好,希望你能理解

具体代码

那看看代码,我没怎么写注释,就几行就能解决,如果不太懂,看看上面的思路

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
int main()
{
	int n , a , b , vmax = 0x3f3f3f3f , vmin = 0;
	cin >> n;
	while(n --)
	{
		cin >> a >> b ;
		vmax = min(vmax , a/b);
		vmin = max(vmin , a/(b+1)+1);
	}
	cout << vmin << " " << vmax << endl; 
	return 0 ;
}

出现一个很变态的事,发现我把int改成longlong就过不了这道题,其实题目范围是在int内,我就是不理解为什么用longlong就不行。

4. 飞机降落

题目描述

【问题描述】

 N 架飞机准备降落到某个只有一条跑道的机场。其中第 i 架飞机在 Ti 时刻 到达机场上空,到达时它的剩余油料还可以继续盘旋 Di 个单位时间,即它最早 可以于 Ti 时刻开始降落,最晚可以于 Ti + Di 时刻开始降落。降落过程需要 Li 个单位时间。 一架飞机降落完毕时,另一架飞机可以立即在同一时刻开始降落,但是不 能在前一架飞机完成降落前开始降落。 请你判断 N 架飞机是否可以全部安全降落。

【输入格式】

输入包含多组数据。 第一行包含一个整数 T,代表测试数据的组数。 对于每组数据,第一行包含一个整数 N。 以下 N 行,每行包含三个整数:Ti,Di 和 Li。

【输出格式】

对于每组数据,输出 YES 或者 NO,代表是否可以全部安全降落。

【样例输入】

2

3

0 100 10

10 10 10

0 2 20

3

0 10 20

10 10 20

20 10 20

【样例输出】

YES

NO

【样例说明】

 对于第一组数据,可以安排第 3 架飞机于 0 时刻开始降落,20 时刻完成降 落。安排第 2 架飞机于 20 时刻开始降落,30 时刻完成降落。安排第 1 架飞机 于 30 时刻开始降落,40 时刻完成降落。

 对于第二组数据,无论如何安排,都会有飞机不能及时降落。

【评测用例规模与约定】

对于 30% 的数据,N ≤ 2。

对于 100% 的数据,1 ≤ T ≤ 10,1 ≤ N ≤ 10,0 ≤ Ti , Di , Li ≤ 10^5。

解题思路

因为这道题的数据范围比较少,我用的是全排列获取了每种情况,分别看是否能成功降落,如果存在一种,就YES,如果全排列的所有情况都不行就NO

具体可以看代码里面的注释

具体代码
// 数据不多 直接全排列列举所有可能 
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
struct point{
	int t , d , l ; //到达 盘旋 降落时间 
}p[24];
void answer()
{
	int n , i , j , t , d , l , now ;
	bool flag = true;
//	a是下表数据,表示所有情况
//	通过全排列a的情况,实则是每架飞机的情况,不同的降落方案 
	int a[14]; // 1<= n <= 10
	cin >> n ;
	for(i = 1; i <= n ; i ++)
	{
		a[i] = i ;
		cin >> p[i].t >> p[i].d >> p[i].l;
	} 
//	开始全排列列举所有情况
//	只要有一种情况满足要求,能成功降落就算YES,否则NO 
	do
	{
		flag = true ; //表示是否成功
		now = 0 ; // 表示此刻的时间, 
		for(i = 1 ; i <= n ; i ++)
		{
			//到达 盘旋 降落时间 
			t = p[a[i]].t , d = p[a[i]].d , l = p[a[i]].l ;
			/*
			我们知道,每架飞机能够成功降落的时间在 t ~ t+l
			那么now可以在三个区间返回内 分别是   now<t    t<=now<=t+l    t+l<now
			1、now > t+l 这种情况肯定不行,现在的时间点已经超过飞机降落 
			2、now <= t+l 这又分两种
				2.1  t<=now 需要这架飞机等一下
				2.2  now<t   需要等飞机在t时间到来,需要等飞机
				一个是飞机等,另一中等飞机 
			*/
			if(now > t+d)
			{
				flag = false ; //失败
				break ; //结束,开始下一组排列情况 
			} 
			else
			{
				if(now >= t)
				{
					now = now + l ;
				}
				else
				{
					now = t + l ;
				}
			}
		}
		if(flag)
		{
//			这组排列满足安排,可行,直接结束就行,只有找到一组情况就行,又不是找最优 
			cout << "YES" << endl;
			return ; 
		}
	}while(next_permutation(a+1 , a+n+1));
	cout << "NO" << endl;
}
int main()
{
	int t;
	cin >> t ;
	while(t --)
	{
		answer();
	}
	return 0 ;
}

5. 接龙数列

题目描述

【问题描述】

对于一个长度为 K 的整数数列:A1, A2, . . . , AK,我们称之为接龙数列当且 仅当 Ai 的首位数字恰好等于 Ai−1 的末位数字 (2 ≤ i ≤ K)。 例如 12, 23, 35, 56, 61, 11 是接龙数列;12, 23, 34, 56 不是接龙数列,因为 56 的首位数字不等于 34 的末位数字。所有长度为 1 的整数数列都是接龙数列。 现在给定一个长度为 N 的数列 A1, A2, . . . , AN,请你计算最少从中删除多少 个数,可以使剩下的序列是接龙序列?

【输入格式】

第一行包含一个整数 N。 第二行包含 N 个整数 A1, A2, . . . , AN。

【输出格式】

一个整数代表答案。

【样例输入】

5

11 121 22 12 2023

【样例输出】

1

【样例说明】

删除 22,剩余 11, 121, 12, 2023 是接龙数列。

【评测用例规模与约定】

对于 20% 的数据,1 ≤ N ≤ 20。

对于 50% 的数据,1 ≤ N ≤ 10000。

对于 100% 的数据,1 ≤ N ≤ 10^5,1 ≤ Ai ≤ 10^9。所有 Ai 保证不包含前导 0。

解题思路

这道题用的dp,dp[i]表示以i(0<=i<=9)为结尾最长可以组成多长,那么答案就是n-max(dp[i]),max(dp[i])是能组成的最长的长度

对于每一个数字,我会用head和tail存下这个数的第一个/最后一个数字的值,

核心:dp[p[i].tail] = max(dp[p[i].tail] , dp[p[i].head] +1);

p[i].head和p[i].tail表示第i个数的头部和尾部

dp[p[i].tail]表示以p[i].tail(0<=p[i].tail<=9)为结尾最长可以组成多长

在dp[p[i].tail](过去的值)和dp[p[i].head] +1求最大值,dp[p[i].head] +1表示在以p[i].head为结尾的数的基础上再加一,家的这个值就是第i个数,

具体代码
// 数据不多 直接全排列列举所有可能 
#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 1e5 + 24; 
struct point{
	int head , tail; //表示的是每一个整数的开头和结尾数字 
}p[N];
int dp[12];  // i(0<=i<=9)为结尾最长可以组成多长
int main()
{
	int n , a , i , j , ans = N;
	cin >> n ;
	for(i = 1 ; i <= n ; i ++)
	{
		cin >> a;
		p[i].tail = a%10;  //尾部数字 
		while(a >= 10)
		{
			a /= 10;
		}
		p[i].head = a; // 头部数据 
	}
	for(i = 1 ; i <= n ; i ++)
	{
		dp[p[i].tail] = max(dp[p[i].tail] , dp[p[i].head] +1);
	} 
	for(i = 0 ; i < 10 ; i ++)
	{
		ans = min(ans , n-dp[i]);
	}
	cout << ans ;
	return 0 ;
}

6. 岛屿个数(待写)

题目描述

【问题描述】

小蓝得到了一副大小为 M × N 的格子地图,可以将其视作一个只包含字符 ‘0’(代表海水)和 ‘1’(代表陆地)的二维数组,地图之外可以视作全部是海水, 每个岛屿由在上/下/左/右四个方向上相邻的 ‘1’ 相连接而形成。 在岛屿 A 所占据的格子中,如果可以从中选出 k 个不同的格子,使得 他们的坐标能够组成一个这样的排列:(x0, y0),(x1, y1), . . . ,(xk−1, yk−1),其中 (x(i+1)%k , y(i+1)%k) 是由 (xi , yi) 通过上/下/左/右移动一次得来的 (0 ≤ i ≤ k − 1), 此时这 k 个格子就构成了一个 “环”。如果另一个岛屿 B 所占据的格子全部位于 这个 “环” 内部,此时我们将岛屿 B 视作是岛屿 A 的子岛屿。若 B 是 A 的子 岛屿,C 又是 B 的子岛屿,那 C 也是 A 的子岛屿。 请问这个地图上共有多少个岛屿?在进行统计时不需要统计子岛屿的数目。

【输入格式】

    第一行一个整数 T,表示有 T 组测试数据。 接下来输入 T 组数据。对于每组数据,第一行包含两个用空格分隔的整数 M、N 表示地图大小;接下来输入 M 行,每行包含 N 个字符,字符只可能是 ‘0’ 或 ‘1’。

【输出格式】

对于每组数据,输出一行,包含一个整数表示答案。

【样例输入】

2

5 5

01111

11001

10101

10001

11111

5 6

111111

100001

010101

100001

111111

【样例输出】

1

3

【样例说明】

对于第一组数据,包含两个岛屿,下面用不同的数字进行了区分: 01111 11001 10201 10001 11111 岛屿 2 在岛屿 1 的 “环” 内部,所以岛屿 2 是岛屿 1 的子岛屿,答案为 1。 对于第二组数据,包含三个岛屿,下面用不同的数字进行了区分: 111111 100001 020301 100001 111111

注意岛屿 3 并不是岛屿 1 或者岛屿 2 的子岛屿,因为岛屿 1 和岛屿 2 中均没有 “环”。

【评测用例规模与约定】

对于 30% 的评测用例,1 ≤ M, N ≤ 10。

对于 100% 的评测用例,1 ≤ T ≤ 10,1 ≤ M, N ≤ 50。

解题思路

暂无,我自己写不出来,先看看别人的,抱歉

具体代码

暂无

7. 子串简写

题目描述

【问题描述】

程序猿圈子里正在流行一种很新的简写方法:对于一个字符串,只保留首 尾字符,将首尾字符之间的所有字符用这部分的长度代替。例如 internationalization 简写成 i18n,Kubernetes (注意连字符不是字符串的一部分)简 写成 K8s, Lanqiao 简写成 L5o 等。 在本题中,我们规定长度大于等于 K 的字符串都可以采用这种简写方法 (长度小于 K 的字符串不配使用这种简写)。 给定一个字符串 S 和两个字符 c1 和 c2,请你计算 S 有多少个以 c1 开头 c2 结尾的子串可以采用这种简写?

【输入格式】

第一行包含一个整数 K。

第二行包含一个字符串 S 和两个字符 c1 和 c2。

【输出格式】

一个整数代表答案。

【样例输入】

4

abababdb a b

【样例输出】

6

【样例说明】

符合条件的子串如下所示,中括号内是该子串:

[abab]abdb

[ababab]db

[abababdb]

ab[abab]db

ab[ababdb]

abab[abdb]

【评测用例规模与约定】

对于 20% 的数据,2 ≤ K ≤ |S | ≤ 10000。

对于 100% 的数据,2 ≤ K ≤ |S | ≤ 5 × 105。S 只包含小写字母。c1 和 c2 都是小写字母。 |S | 代表字符串 S 的长度。

解题思路

题意很好理解,其实就算找长度大于等于k且以 c1 开头 c2 结尾的连续子串的个数

这里用的是dp,大家可以看我的代码里面的注释

具体代码

#include <bits/stdc++.h>
using namespace std;
typedef long long ll;
const int N = 5e5 + 24; 
string s;
ll num[N];
int main()
{
	int k , i , j ;
	ll ans = 0 ;
	char c1 , c2 ;
	cin >> k ;
	cin >> s >> c1 >> c2;
//	1、num[i]表示到第i个字符,c1字符的个数 ,从第一个字符开始 
	for(i = 1 ; i <= s.size() ; i ++)
	{
//		动态规划 
		num[i] = num[i-1] + (s[i-1] == c1);
	}
//	2、从第k歌字符开始,如果 第i个字符s[i-1]等于c2,则以s[i]结尾字符为c2的个数有 num[i-k]个,这个自己可以推算一下 
	for(i = k ; i <= s.size() ; i ++)
	{
		if(s[i-1] == c2)
		{
			ans += num[i-k+1];   //我num的下标是从1开始的,所以这里要加1 
		}
	} 
	cout << ans ; 
	return 0; 
}

8. 整数删除(待写)

题目描述 

【问题描述】
  给定一个长度为 N 的整数数列:A1, A2, . . . , AN。你要重复以下操作 K 次:
每次选择数列中最小的整数(如果最小值不止一个,选择最靠前的),将其删除。并把与它相邻的整数加上被删除的数值。输出 K 次操作后的序列。

【输入格式】
第一行包含两个整数 N 和 K。
第二行包含 N 个整数,A1, A2, A3, . . . , AN。

【输出格式】
输出 N − K 个整数,中间用一个空格隔开,代表 K 次操作后的序列。

【样例输入】

5 3
1 4 2 8 7
1
2
【样例输出】

17 7
1
【样例说明】
数列变化如下,中括号里的数是当次操作中被选择的数:

[1] 4 2 8 7
5 [2] 8 7
[7] 10 7
17 7
1
2
3
4
【评测用例规模与约定】
对于 20% 的数据,1 ≤ K < N ≤ 10000。
对于 100% 的数据,1 ≤ K < N ≤ 5 × 105,0 ≤ Ai≤ 108。

解题思路

用优先级队列动态地获取最小的数,时间复杂度为O(N*logN)
1、用懒标记标记删除的点,在队列中获取数据时判断是否被标记删除,是则丢弃,否则就是要取的点
2、删除当前节点后,左右节点加上当前节点的值,并且左节点的右节点更新为当前节点的右节点、右节点的左节点更新为当前节点的左节点
模拟这个过程即可

具体代码

这个还没做完,后面几道有点难,我要想一下,今天就不写了,如果有问题,麻烦大家指出一下,谢谢。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1422785.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

性价比高的蓝牙运动耳机推荐,公认好用的运动耳机品牌推荐

​随着人们对健康的重视&#xff0c;越来越多的人选择加入运动行列。然而&#xff0c;独自运动可能会让人感到乏味&#xff0c;因此许多人在运动时都会选择佩戴运动耳机&#xff0c;让音乐伴随整个运动过程。那么&#xff0c;如何挑选适合自己的运动耳机呢&#xff1f;今天我为…

2024美赛数学建模E题思路+代码

文章目录 1 赛题思路2 美赛比赛日期和时间3 赛题类型4 美赛常见数模问题5 建模资料 1 赛题思路 (赛题出来以后第一时间在CSDN分享) https://blog.csdn.net/dc_sinor?typeblog 2 美赛比赛日期和时间 比赛开始时间&#xff1a;北京时间2024年2月2日&#xff08;周五&#xff…

【Docker】在Windows下使用Docker Desktop创建nginx容器并访问默认网站

欢迎来到《小5讲堂》&#xff0c;大家好&#xff0c;我是全栈小5。 这是《Docker容器》序列文章&#xff0c;每篇文章将以博主理解的角度展开讲解&#xff0c; 特别是针对知识点的概念进行叙说&#xff0c;大部分文章将会对这些概念进行实际例子验证&#xff0c;以此达到加深对…

品牌运营如何打造出独特的风格?

在上网冲浪日益普遍&#xff0c;在线营销失去神秘的当下&#xff0c;品牌如果一味强调人设&#xff0c;只会浪费宣传成本。从老钱风、静奢风的兴起到多巴胺、美拉德的流行&#xff0c;后消费时代的运营需要注重风格的独特化&#xff0c;与消费者进行真诚沟通&#xff0c;今天媒…

vue3开发,axios发送请求是携带params参数的避坑

vue3开发,axios发送请求是携带params参数的避坑&#xff01;今天一直报错&#xff0c;点击新增购物车&#xff0c;报错&#xff0c; 【Uncaught (in promise) TypeError: target must be an object】。查询了网上的资料说的都不对。都没有解决。最终还是被我整明白了。 网上网…

项目实战:一个基于标准库的具备最值获取的万能容器实现

目录 写在前面 需求 分析 接口设计 项目实现 一些思考与总结 致谢 写在前面 刚刚介绍了变参模板和完美转发&#xff0c;现在换一换脑子做一个小的项目实战吧。博主最近学习的是标准库&#xff0c;总体来说&#xff0c;我认为标准库中的内容是很trivial的&#xff0c;重点…

蓝桥杯 第 1 场 小白入门赛

目录 1.蘑菇炸弹 2.构造数字 3.小蓝的金牌梦 4.合并石子加强版 5.简单的LIS问题 6.期望次数 1.蘑菇炸弹 我们直接依照题目 在中间位置的数进行模拟即可 void solve(){cin>>n;vector<int> a(n1);for(int i1;i<n;i) cin>>a[i];int ans0;for(int i2;i…

uniapp底部栏设置未读红点或角标

pages.json {... // 省略"tabBar": {"color": "#333333","selectedColor": "#3296fa","backgroundColor": "#ffffff","borderStyle": "white","list": [{"pagePat…

【Go】Viper读取配置文件

go get github.com/spf13/viper 1. 设置配置文件的信息 etcd:ip: "192.168.6.106"port: 2379dialTimeout: 3redis:ip: "192.168.6.107"port: 6379password: "root1028"2. 读取配置文件的信息 2.1 通过kv的方式 package mainimport ("fm…

【Tomcat与网络5】再论Tomcat的工作过程与两种经典的设计模式

前面两篇&#xff0c;我们重点分析了Tomcat的容器和连接器的基本设计&#xff0c;今天我们来看一下两个机构如何在service的调度下进行协同工作的。 目录 1.模板模式与Tomcat的重用性设计 2.观察者模式与Tomcat可扩展性设计 1.模板模式与Tomcat的重用性设计 首先&#xff0…

电脑护眼模式怎么设置?4个有效方法保护眼睛!

“我感觉每天使用电脑的时间久了&#xff0c;眼睛总是不太舒服。电脑护眼模式怎么设置呢&#xff1f;有什么比较好用的方法可以推荐吗&#xff1f;” 如果长时间使用电脑&#xff0c;或许会让我们感到用眼疲劳。电脑护眼模式是现代人常用的电脑设置之一&#xff0c;它能有效地减…

通俗易懂三大范式

通俗易懂三大范式 第一范式说的是每个字段不可再分 第二范式说的是不能存在部分依赖&#xff08;不能由联合主键的部分就可以推出其他字段&#xff0c;必须整个联合主键才能推出其他字段&#xff09; 第三范式说的是不能存在间接依赖(A&#xff08;主键&#xff09;→B,B→C…

wordcloud库和jieba库的使用

文章目录 wordcloud库的简单示范使用wordcloud库报错记录anaconda安装第三方jieba库jieba库的简单示范任务 1&#xff1a;三国演义中的常见词汇分布在“三国"这两个隶书字上&#xff0c;出现频率高的词字体大任务 2&#xff1a;三国演义中出现频率前十的人名。必须是以下这…

【日常总结】windows11 设置文件默认打开方式

一、场景 二、实战 Stage 1&#xff1a;打开设置 Stage 2&#xff1a;应用 > 默认应用 > 搜索 .txt Stage 3&#xff1a;修改成notepad &#xff0c;设置默认值即可 一、场景 windows 11 .txt 默认记事本打开 需求&#xff1a;如何使用notepad打开呢 &#xff1f;…

App Inventor 2 低功耗蓝牙(BLE) 硬件接入、数据通信及IO控制

低功耗蓝牙(BLE)以低功耗、低成本、开发简便逐渐被广泛应用&#xff0c;本文主要介绍一款较为通用、价格低廉的BLE设备从零开始如何利用App Inventor 2开发一款自己专属的手机蓝牙App应用。 BLE与经典蓝牙的区别可参考&#xff1a;《低功耗蓝牙(BLE) 和 经典蓝牙(SPP) 的区别》…

一张序列图搞懂resilience4j的工作原理

本文主要回答以下几个问题&#xff1a; Spring Cloud与Resilience4j如何集成的&#xff08;spring-cliud-circuitbreaker-resilience4j模块的 Resilience4JAutoConfiguration类实现了主要组件的注入&#xff0c;特别是在Resilience4jBulkheadConfiguration中定义如何自定义fac…

Qt简易的五子棋

五子棋是个简单的小游戏&#xff0c;尝试使用Qt将他做出来&#xff0c;学习时的练习demo。 成果展示 需求分析 五子棋&#xff1a;在棋盘上&#xff0c;黑棋先行&#xff0c;交替下棋&#xff0c;五子练成直线获取胜利。 实现过程 1.棋盘绘制&#xff1a;下棋的第一步肯定是绘制…

ubuntu gedit主题更改

ubuntu16.04 gedit 编辑器又有首选项如何设置主题 这里下载主题 将主题XML复制到 /usr/share/gtksourceview-3.0/styles 文件夹内&#xff1b; 使用gsettings 命令设置喜欢的配色方案&#xff0c;使用方式如下&#xff1a;(实测不带.xml后缀哦) gsettings set org.gnome.gedi…

本地配置Joplin Server用于Joplin笔记同步并实现公网远程访问

文章目录 1. 安装Docker2. 自建Joplin服务器3. 搭建Joplin Sever4. 安装cpolar内网穿透5. 创建远程连接的固定公网地址 Joplin 是一个开源的笔记工具&#xff0c;拥有 Windows/macOS/Linux/iOS/Android/Terminal 版本的客户端。多端同步功能是笔记工具最重要的功能&#xff0c;…

小程序定制开发:解析定制化移动应用的未来

引言 在当今数字化时代&#xff0c;移动应用已经成为人们生活不可或缺的一部分。随着智能手机的普及&#xff0c;移动应用的需求呈现出爆发式增长&#xff0c;企业们也纷纷投身于这场数字化浪潮。然而&#xff0c;众多企业在竞争激烈的市场中&#xff0c;如何突显个性、提高用…