【string的反转和删除和字符串比大小】2019年华南理工大学程序设计竞赛(春季赛)C.六学家的困惑

2019年华南理工大学程序设计竞赛(春季赛)C.六学家的困惑

链接:https://ac.nowcoder.com/acm/contest/625/C
来源:牛客网
 

小六喜欢两全其美的事情,今天就正好有一个这样的机会。

小六面前有两根管子,管子里面放满了数字为1到9的小球。每次取球时,小六会先选择一根管子,再从这根管子的某一侧(左侧或右侧)取出一个球。在满足取球规则的情况下,他可以任意顺序取出所有小球。假如小六依次取出的球的编号为a1,a2,⋯,ana1,a2,⋯,an,则他最后就得到了一个形如¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯¯a1a2⋯ana1a2⋯an¯样的十进制数。

小六希望他的取球顺序所组成的数是最大的,你可以帮一下他吗?

输入描述:

第一行输入数据组数。T (T≤14)T (T≤14)

接下来T行,每行输入两串只含1∼91∼9的数字,表示两根管子里的小球的数字。每根管子内至少含1个小球,且数量不超过40个。

输出描述:

对每一组数据,输出一行Case #x: A,其中x是数据组数编号(从1开始),A是小六能组成的最大的数。

示例1

输入

复制

2
123456 123456
9876346789 9854894589

输出

复制

Case #1: 665544332211
Case #2: 99998888776655498443

题意:给你两个字符串,每一位只在1-9中

           每次可以取这两个字符串中的头或尾

            要求最后输出的答案字典序最大

思路:

用string直接比大小

分别是a字符串,b字符串,a的反转字符串,b的反转字符串

然后如果a最大,删去a的第一个字符和c的最后一个字符

其他相似

把答案输入queue,然后输出

 

string反转:reverse(c.begin(), c.end());
string删除字符:str.erase(pos,k):从第pos位删除k个(pos在0-len-1)
#include <bits/stdc++.h>
using namespace std;
string a,b,c,d;

queue <int> q;

int tmp()
{
	if(a>=b&&a>=c&&a>=d)
	{
		q.push(a[0]-'0');
		a.erase(0,1);
		int len=c.length();
		c.erase(len-1,1);
		return 1;
	}
	else if(b>=a&&b>=c&&b>=d)
	{
		q.push(b[0]-'0');
		b.erase(0,1);
		int len=d.length();
		d.erase(len-1,1);
		return 2;
	}
	else if(c>=a&&c>=b&&c>=d)
	{
		q.push(c[0]-'0');
		c.erase(0,1);
		int len=a.length();
		a.erase(len-1,1);
		return 3;
	}
	else
	{
		q.push(d[0]-'0');
		d.erase(0,1);
		int len=b.length();
		b.erase(len-1,1);
		return 4;
	}
}

int main()
{
	int T;
	int cas=0;
	scanf("%d",&T);
	while(T--)
	{
		//f1=f2=f3=f4=0;
		cin>>a>>b;
		int len1=a.length();
		int len2=b.length();
		c=a,d=b;
		reverse(c.begin(), c.end());
		reverse(d.begin(), d.end());

		for(int i=1;i<=len1+len2;i++)
		{
			int k=tmp();
		}

		printf("Case #%d: ",++cas);
		while(!q.empty())
		{
			int k=q.front();
			q.pop();
			printf("%d",k);
		}
		cout<<endl;
	}
	return 0;
}

 

1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看REAdMe.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READme.md或论文文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 5、资源来自互联网采集,如有侵权,私聊博主删除。 6、可私信博主看论文后选择购买源代码。
1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。 、 1资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看READmE.文件(md如有),本项目仅用作交流学习参考,请切勿用于商业用途。 1、资源项目源码均已通过严格测试验证,保证能够正常运行; 2、项目问题、技术讨论,可以给博主私信或留言,博主看到后会第一时间与您进行沟通; 3、本项目比较适合计算机领域相关的毕业设计课题、课程作业等使用,尤其对于人工智能、计算机科学与技术等相关专业,更为适合; 4、下载使用后,可先查看README.md文件(如有),本项目仅用作交流学习参考,请切勿用于商业用途。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值