锦绣育才【集训题】最大的和

描述

李老师发现了一条由 n 个单元格组成的条带,从左到右编号 1~n。在第 i 个单元格中,有一个正整数 ai 和一个字母 si,其中所有 si 要么是 ‘L’,要么是 ‘R’。

在一次操作中,你可以选择两个索引 l 和 r (1 ≤ l < r ≤ n),使得 s[l] = ‘L’ 且 s[r] = ‘R’,并执行以下操作,将 a[l] + a[l+1] + …… +a[r-1] + a[r] 的分数加到当前得分中,同时你无法再选择这些位置的索引 !!!

例如,对于下面的条带:

image.png

你可以首先选择 l = 1,r = 2,并将 3 + 5 = 8 加到你的得分中
然后选择 l = 3, r = 6,并将 1 + 4 + 3 + 2 加到你的得分中
总得分为 18

李老师邀请你尝试通过执行任意(可能为零)次数的操作来获得尽可能高的分数。

输入描述

第一行包含一个整数 t(1 <= t <= 100) — 测试用例的数量
每个测试用例的第一行包含一个整数 n(2 <= n <= 1e5)— 条带的长度
每个测试用例的第二行包含 n 个整数 ai (2 <= ai <= 1e5)— 写在条带上的数字
每个测试用例的第三行包含一个字符串 s,由 n 个字符 ‘L’ 和 ‘R’ 组成

输出描述

对于每个测试用例,输出一个整数 — 可以获得的最高分数

用例输入 1

4
6
3 5 1 4 3 2
LRLLLR
2
2 8
LR
2
3 9
RL
5
1 2 3 4 5
LRLRR
用例输出 1

18
10
0
22

得开O2

#include <bits/stdc++.h>
#define ll long long//懒惰
using namespace std;
ll s[100030];
char ss[100030];
int main(){
    ios::sync_with_stdio(false);
	cin.tie(0);//流加速
    ll t;
    cin>>t;
    while(t--){
    	memset(s,0,sizeof(s));
    	ll n;
    	cin>>n;
    	for(int i=1;i<=n;i++){
    		cin>>s[i];
    		s[i]=s[i]+s[i-1];//求前缀和
		}
		for(int i=1;i<=n;i++){
    		cin>>ss[i];
		}
		ll l=1,r=n;
		ll sum=0;
		while(l<r){
			while(l<r&&ss[l]=='R')l++;
			while(l<r&&ss[r]=='L')r--;
			if(l<r) sum+=s[r]-s[l-1];//加上区间和
			l++,r--;//手动推指针
			}
		cout<<sum<<endl;
		}
}
代码下载地址: https://pan.quark.cn/s/b4a8e0160cfc 齿轮与轴系零件在机械设备中扮演着至关重要的角色,它们负责实现动力传输、调整运动形态以及承受工作载荷等核心功能。 在机械工程的设计实践中,齿轮轴系的设计是一项关键的技术任务,其内容涵盖了材料选用、构造规划、承载能力分析等多个技术层面。 下面将系统性地介绍《齿轮及轴系零件结构设计指导书》中的核心知识点。 一、齿轮设计1. 齿轮种类:依据齿廓轮廓的不同,齿轮可划分为直齿齿轮、斜齿轮以及人字齿轮等类别,各类齿轮均具有特定的性能特点与适用工况,能够满足多样化的工作环境与载荷需求。 2. 齿轮规格参数:模数大小、压力角数值、齿数数量、分度圆尺寸等是齿轮设计的基础数据,这些参数直接决定了齿轮的物理尺寸与运行性能。 3. 齿轮材质选用:齿轮材料的确定需综合评估其耐磨损性能、硬度水平以及韧性表现,常用的材料包括铸铁、钢材、铝合金等。 4. 齿轮强度验证:需进行齿面接触应力分析与齿根弯曲应力分析,以确保齿轮在实际运行过程中不会出现过度磨损或结构破坏。 5. 齿轮加工工艺:涉及切削加工、滚齿加工、剃齿加工、淬火处理等工艺流程,工艺方案的选择将直接影响齿轮的加工精度与使用寿命。 二、轴设计1. 轴的分类方式:依据轴在机械装置中的功能定位与受力特点,可将轴划分为心轴、转轴以及传动轴等类型。 2. 轴的材料选择:通常采用钢材作为轴的材料,例如碳素结构钢或合金结构钢,特殊需求时可选用不锈钢材料或轻质合金材料。 3. 轴的构造规划:需详细考虑轴的轴向长度、截面直径、键槽布置、轴承安装位置等要素,以满足轴的强度要求、刚度要求以及稳定性要求。 4. 轴的强度验证:需进行轴的扭转强度分析与弯曲强度分析,以防止轴在运行过程中发生塑性变形...
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

༺ཌༀ傲穹_Vortexༀད༻

你的鼓励奖是我最大的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值