[技巧篇]string的巧用(cf 387C)

本文通过Codeforces387C题实例,详细解析了如何使用字符串处理大数比较的问题,分享了一种从后往前比较的算法思路,对于理解字符串在处理大数时的应用及提高算法效率有一定帮助。

以codeforces387C题为例

#include<bits/stdc++.h>
using namespace std;
string s,a[100005];
bool cmp(string a,string b){
	int A=a.size();
	int B=b.size();
	if(A<B) return false;
	else if(A>B) return true;
	else{
		for(int i=0;i<A;i++){
			if(a[i]>b[i]) return true;
			else if(a[i]<b[i]) return false;
		}
	}
	return true;
}
int main(){
	while(cin>>s){
		int len=s.size(),cnt=0,ans=1;
		for(int i=0;i<len;i++){
			a[cnt]+=s[i];
			while(s[i+1]=='0'){
				a[cnt]+=s[i+1];
				i++;
			}
			cnt++;
		}
		string Max=a[0];
		for(int i=1;i<cnt;i++){
			if(cmp(Max,a[i]))  ans++;
			else ans=1;
			Max+=a[i];
		}
		cout<<ans<<endl;	
	}
	return 0;
}

我想说的是:
当出现大数的时候,我们可以改变思路使用字符串来。但是如果说比较大小或者位数,我们可以先比较两个数的位数(注意string中用的是x.size()),然后倘若两者位数相等的话,我们可以遍历这个string长度,然后依次比较,直到遇到大的break.

ps:这个题我一开始题目意思理解错了,导致wa了。不过我觉得我写的还是在某一种程度上有一定借鉴意思,虽然与题意背道而驰。

My ideas:
从后往前比较,遇到比这大的就cnt++。

#include<bits/stdc++.h>
using namespace std;
int main()
{
	char s[1000];
	int  b[1000];
	while(cin>>s){
		for(int i=0;i<=strlen(s);i++){
			b[i]=s[i]-'0';
		}
		int cnt=1;
		int l=strlen(s);
		int presum=b[l-1];
		int now=l-2;
		if(presum==0) {
			now=l-1;
			cnt=0;
		}
		int j=1;
		int q=0;
		while(now>=0){
			if(now-j+1<0) break;
			int sum=0;
			for(int i=now;i>=now-j+1;i--){
				sum+=b[i]*pow(10,q);
				q++;
 			} 
			if(sum!=0&&sum>=presum){
				presum=sum;
				cnt++;
				q=0;
				now=now-j;
			}
			else{
				j++;
				q=0;
			}
		}
		cout<<cnt<<endl;
	}
}
内容概要:本文围绕可变桨叶四旋翼无人机的规范控制与点对点运动模拟展开,重点研究优化推力分配策略在翻转动作中的应用与性能比较。通过Matlab代码实现,构建了四旋翼动力学模型,并设计了多种控制算法以实现精确的姿态调整与轨迹跟踪。研究对比了不同推力分配方案在执行高机动性翻转动作时的稳定性、能耗效率与响应速度,旨在提升无人机在复杂飞行任务中的动态性能与控制精度。该仿真研究为无人机飞控系统的设计与优化提供了理论依据和技术支持。; 适合人群:具备一定自动控制理论基础和Matlab编程能力,从事无人机控制、飞行器动力学或机器人系统研究的科研人员及研究生。; 使用场景及目标:① 实现四旋翼无人机在三维空间中的精确点对点运动控制;② 对比分析不同推力分配策略在执行翻转等高难度动作时的控制效果与能耗表现,优化飞行性能;③ 为无人机自主飞行、特技飞行及复杂环境下的机动控制提供算法验证平台。; 阅读建议:此资源以Matlab仿真为核心,建议读者结合相关控制理论知识,深入理解代码实现细节,重点关注动力学建模、控制律设计与推力分配模块。在学习过程中,应动手调试参数,复现文中翻转动作的仿真结果,并尝试拓展至其他复杂飞行任务,以加深对无人机控制机理的理解。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值