poj1146

poj1146题目链接:http://poj.org/problem?id=1146题目大意:求一个字符串的后继字符串,即对一个字符串进行字典序排列的后一个!方法:对字符串进行从后向前进行遍历,如果直到找到后面的最大的非递增序列,然后在这个序列中找到比其前面大的最小的一个字母和其交换,再对交换后的后面的部分进行字典序排列再次进行输出即可以拉!#include#includeusingnam

大家好,又见面了,我是你们的朋友全栈君。

题目链接:http://poj.org/problem?id=1146

题目大意:求一个字符串的后继字符串,即对一个字符串进行字典序排列的后一个!

方法:对字符串进行从后向前进行遍历,如果直到找到后面的最大的非递增序列,然后在这个序列中找到比其前面大的最小的一个字母和其交换,再对交换后的后面的部分进行字典序排列再次进行输出即可以拉!

#include<iostream>
#include<string>
using namespace std;
int cmp(const void *a,const void *b)
{
	return *(char *)a-*(char *)b;
}
int main()
{
	char s[60];
	int i,j,sign,len;
	while(1)
	{
		gets(s);
		sign=0;
		len=strlen(s);
		if(len==1 && s[0]=='#')
			break;
		for(i=len-1; i>=1; i--)
			if(s[i-1]<s[i])
			{
				sign=1;
				break;
			}
		if(sign==0)
			printf("No Successor\n");
		else
		{ 
			char ma=120;
			int k;
			for(j=i; j<len; j++)
				if(s[j]<ma && s[j]>s[i-1])
				{
					ma=s[j];
					k=j;
				}
			char m=s[i-1];
			s[i-1]=s[k];
			s[k]=m;
			qsort(&s[i],len-i,sizeof(char),cmp);
			for(j=0; j<len; j++)
				printf("%c",s[j]);
             printf("\n");
		}
	}
	return 0;
}

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/139939.html原文链接:https://javaforall.net

(0)
上一篇 2022年5月28日 下午11:16
下一篇 2022年5月28日 下午11:16


相关推荐

  • linux实现文件共享samba,Linux环境下实现SAMBA服务文件共享[通俗易懂]

    linux实现文件共享samba,Linux环境下实现SAMBA服务文件共享[通俗易懂]一、实现SMB共享1、在服务器安装软件包yum-yinstallsamba2、创建samba用户和组groudadd-radminsuseralfa-Gadmins-s/sbin/nologinsmbpasswd-aalfauseaddbmw-s/sbin/nologinsmbpasswd-abmw3、创建samba共享目录,并设置SElinux新建一个目录或者用…

    2026年3月3日
    9
  • 决策树分析例题经典案例_决策树例题分析及解答

    决策树分析例题经典案例_决策树例题分析及解答决策树例题分析及解答 1 例 某农业企业有耕地面积 33 333 公顷 可供灌水量 6300 立方米 在生产忙季可供工作日 2800 个 用于种植玉米 棉花和花生三种作物 预计三种作物每公顷在用水忙季用工日数 灌水量和利润见表 在完成 16 5 万公斤玉米生产任务的前提下 如何安排三种作物的种植面积 以获得最大的利润 2 解 玉米 棉花 花生和种植面积分别为 X1 X2 X3 公顷 依题意列出线性规划模型 目标

    2025年7月2日
    7
  • go语言微服务之RPC协议[通俗易懂]

    go语言微服务之RPC协议[通俗易懂]1什么是RPCRemoteProcedureCallProtocol–远程过程调用协议!IPC:进程间通信RPC:远程进程通信–应用层协议(http协议同层),底层用TCP实现。理解RPC:像调用本地函数一样,去调用远程函数。通过rpc协议,传递:函数名,函数参数。达到在本地,调用远端函数,得返回值到本地的目标。 为什么微服务要使用RPC:每个服务都被封转成进程,彼此“独立”。 进程与进程之间,可以使用不同的语言实现。2RPC使用的步骤服务端:注册rpc

    2022年5月12日
    61
  • Idea激活码最新教程2024.2版本,永久有效激活码,亲测可用,记得收藏

    Idea激活码最新教程2024.2版本,永久有效激活码,亲测可用,记得收藏Idea 激活码教程永久有效 2024 2 激活码教程 Windows 版永久激活 持续更新 Idea 激活码 2024 2 成功激活

    2025年5月28日
    9
  • SQL存储过程详解

    SQL存储过程详解存储过程解答

    2026年3月26日
    2
  • git提交代码常用命令

    git提交代码常用命令git 使用常用命令使用 git 提交代码命令执行步骤 命令如下 gitadd 使用此种方式提交的一个弊端就是会提交项目中所有新增或者修改的文件 建议使用 idea 自带的提交方式 选择性的提交文件 gitcommit m 实现了 abc 下载及更新服务 提供返回目录 文件和文件夹 的接口 可下载相应的文件 gitpullgitpu 撤销 1 使用 gitlog 命令查看 commit 的历史 2 gitresethard

    2025年11月1日
    5

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号