如何使用java解决下一个排列的问题

这篇文章主要为大家展示了如何使用java解决下一个排列的问题,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带大家一起来研究并学习一下“如何使用java解决下一个排列的问题”这篇文章吧。

创新互联公司主营南岔网站建设的网络公司,主营网站建设方案,重庆APP软件开发,南岔h5微信小程序搭建,南岔网站营销推广欢迎南岔等地区企业咨询

实现获取下一个排列的函数,算法需要将给定数字序列重新排列成字典序中下一个更大的排列。

如果不存在下一个更大的排列,则将数字重新排列成最小的排列(即升序排列)。

必须原地修改,只允许使用额外常数空间。

以下是一些例子,输入位于左侧列,其相应输出位于右侧列。
1,2,3 → 1,3,2
3,2,1 → 1,2,3
1,1,5 → 1,5,1

如何使用java解决下一个排列的问题

解析:

dict是每个单词出现的次数,在下面的while循环中查找使用,如果查找某个单词的数量大于words中某个单词出现的次数就会终止当前循环。其中words中每个单词的长度都是一样的,wordlen是单个单词的长度,totalLen是words中所有单词的长度,在下面的for和while循环中,相当于每次从源字符串s中截取长度为totalLen的子字符串,然后每次再从子字符串中截取长度为wordLen的字符串存放到found中,当found中某个字符串大于dict中某个字符串的时候终止while循环,否则继续查找,直到查找的长度大于totalLen的时候则终止while循环,然后再对比。如果还是不太明白,for循环中还可以这样写,每次截取长度为totalLen的字符串,然后再把长度为totalLen的字符串分别截取长度为wordLen的字符串,最会在和words中的字符串逐个对比即可。

常用的java框架有哪些

1.SpringMVC,Spring Web MVC是一种基于Java的实现了Web MVC设计模式的请求驱动类型的轻量级Web框架。2.Shiro,Apache Shiro是Java的一个安全框架。3.Mybatis,MyBatis 是支持普通 SQL查询,存储过程和高级映射的优秀持久层框架。4.Dubbo,Dubbo是一个分布式服务框架。5.Maven,Maven是个项目管理和构建自动化工具。6.RabbitMQ,RabbitMQ是用Erlang实现的一个高并发高可靠AMQP消息队列服务器。7.Ehcache,EhCache 是一个纯Java的进程内缓存框架。

以上就是关于“如何使用java解决下一个排列的问题”的内容,如果该文章对你有所帮助并觉得写得不错,劳请分享给你的好友一起学习新知识,若想了解更多相关知识内容,请多多关注创新互联行业资讯频道。


文章题目:如何使用java解决下一个排列的问题
转载来源:http://scyanting.com/article/pecipi.html