当前位置: 首页 > news >正文

德兴高端网站设计广东建筑企业100强

德兴高端网站设计,广东建筑企业100强,亚马逊全球开店,怎么知道自己网站的权重题目 给定一个只包含大写英文字母的字符串S,要求你给出对S重新排列的所有不相同的排列数。如:S为ABA,则不同的排列有ABA、AAB、BAA三种。 解答要求 时间限制:5000ms,内存限制:100MB 输入描述 输入一个长度不超过10的字符串S,确保都是大写的。…

题目

给定一个只包含大写英文字母的字符串S,要求你给出对S重新排列的所有不相同的排列数。如:S为ABA,则不同的排列有ABA、AAB、BAA三种。
解答要求
时间限制:5000ms,内存限制:100MB
输入描述
输入一个长度不超过10的字符串S,确保都是大写的。
输出描述
输出S重新排列的所有不相同的排列数(包含自己本身)。
示例1:
输入
ABA
输出
3
示例2:
输入
ABCDEFGHHA
输出
907200

思路

求含重复元素的排列总数,两种方法(数学法效率远高于dfs):

  1. dfs列举所有排列,得到总数,只需要总数,不需要具体组合,具体思路详见:【JAVA-排列组合】一个套路速解排列组合题
  2. 数学公式法

比如输入数据为:ABCDDDA
不考虑重复数据,总的排列数为:res=7!
统计重复元素出现次数:A出现2次,D出现3次,其他出现1次
所以最后结果为:res=7!/(2!*3!)=420

备注:数学法可以这样理解,不考虑重复,那么n个元素的排列方法为n!,再去重,比如某个元素有3个,在不去重时,它重复了3!次,去重时直接除掉它就可以了

题解

package hwod;import java.util.*;public class ArrangeInOrder {public static void main(String[] args) {Scanner sc = new Scanner(System.in);String str = sc.nextLine();System.out.println(arrangeInOrder(str));System.out.println(arrangeInOrder2(str));}private static int res;private static int arrangeInOrder(String str) {final char[] chars = str.toCharArray();Arrays.sort(chars);int[] used = new int[chars.length];dfs(chars, used, 0);return res;}private static void dfs(char[] chars, int[] used, int len) {if (len == chars.length - 1) {//确定到倒数第二位即可res++;return;}for (int i = 0; i < chars.length; i++) {if (i > 0 && chars[i] == chars[i - 1] && used[i - 1] == 0) continue;if (used[i] == 1) continue;used[i] = 1;dfs(chars, used, len + 1);used[i] = 0;}}//方案二:数学法private static int arrangeInOrder2(String str) {Map<Character, Integer> map = statisticsCnt(str);int size = str.length();long res = getFactorialNum(size);int divide = 1;for (Character key : map.keySet()) {divide *= getFactorialNum(map.get(key));}return (int) (res / divide);}private static Map<Character, Integer> statisticsCnt(String string) {Map<Character, Integer> map = new HashMap<>();for (int i = 0; i < string.length(); i++) {map.put(string.charAt(i), map.getOrDefault(string.charAt(i), 0) + 1);}return map;}/*** @param n* @return 计算阶乘*/private static long getFactorialNum(long n) {if (n == 1) return 1;return n * getFactorialNum(n - 1);}
}

推荐

如果你对本系列的其他题目感兴趣,可以参考华为OD机试真题及题解(JAVA),查看当前专栏更新的所有题目。

说明

本专栏所有文章均为原创,欢迎转载,请注明文章出处:https://blog.csdn.net/qq_31076523/article/details/134176793。百度和各类采集站皆不可信,搜索请谨慎鉴别。技术类文章一般都有时效性,本人习惯不定期对自己的博文进行修正和更新,因此请访问出处以查看本文的最新版本。

http://www.yayakq.cn/news/17278/

相关文章:

  • 做外汇网站代理商网站集约化建设管理方案
  • 网站建设信息推荐莱芜金点子电子版最新招聘信息
  • qq在线登录手机版网站seo的主要优化内容
  • 静态网站flash设计兼职网站
  • 一般纳税人网站建设多少税率信阳市网站建设公司
  • 涞水县住房和城乡建设局网站一个网站放两个vps
  • 网站建设用户登录三水容桂网站制作
  • 购物网站功能专业建设成效
  • 附近做网站深圳做网站和视频宣传机构
  • 无锡市住房与城乡建设网站什么公司做网站最好
  • 国外网站建设 网站中铁建设集团门户网站登陆
  • 网站免费加速器学产品设计的可以找什么工作
  • 蓝色网站设计网站设计的软件
  • 手机研发流程昆明官网优化公司
  • 企业门户网站模板物流公司网站建设有什么要点
  • 哪个网站上可以做代打做网站如何买量
  • 琶洲网站建设网站平台建设合同模版
  • 做纺织外贸哪个贸易网站好会计上大额网站费如何做分录
  • 衡水企业网站建设做一款游戏app需要多少钱
  • 转转网站怎么建设凡客app官网
  • 福州小学网站建设校园网站建设的用处
  • ip钓鱼网站在线生成做网站程序的步骤
  • 工程建设标准下载网站codepen wordpress
  • 域名绑定网站公司网站开发人员离职后修改公司网站
  • 建设电影网站的关键上海市建筑工程有限公司
  • 保护稀有动物网站建设策划书影视设计
  • 哪个浏览器可以看禁止访问的网站毕业设计做网站做什么好
  • 做网站选择什么相机用ps给旅游网站做前端网页
  • 淘宝的网站建设做三维特效的好网站
  • 培训学校网站建设方案wordpress中文采集插件