日韩性视频-久久久蜜桃-www中文字幕-在线中文字幕av-亚洲欧美一区二区三区四区-撸久久-香蕉视频一区-久久无码精品丰满人妻-国产高潮av-激情福利社-日韩av网址大全-国产精品久久999-日本五十路在线-性欧美在线-久久99精品波多结衣一区-男女午夜免费视频-黑人极品ⅴideos精品欧美棵-人人妻人人澡人人爽精品欧美一区-日韩一区在线看-欧美a级在线免费观看

歡迎訪問 生活随笔!

生活随笔

當前位置: 首頁 > 编程资源 > 编程问答 >内容正文

编程问答

蓝桥杯java第五届决赛第四题--排列序数

發布時間:2025/3/20 编程问答 22 豆豆
生活随笔 收集整理的這篇文章主要介紹了 蓝桥杯java第五届决赛第四题--排列序数 小編覺得挺不錯的,現在分享給大家,幫大家做個參考.
標題:排列序數如果用a b c d這4個字母組成一個串,有4!=24種,如果把它們排個序,每個串都對應一個序號:abcd 0abdc 1acbd 2acdb 3adbc 4adcb 5bacd 6badc 7bcad 8bcda 9bdac 10bdca 11cabd 12cadb 13cbad 14cbda 15cdab 16cdba 17...現在有不多于10個兩兩不同的小寫字母,給出它們組成的串,你能求出該串在所有排列中的序號嗎?【輸入格式】一行,一個串。【輸出格式】一行,一個整數,表示該串在其字母所有排列生成的串中的序號。注意:最小的序號是0。例如:輸入:bdca程序應該輸出:11再例如:輸入:cedab程序應該輸出:70資源約定:峰值內存消耗(含虛擬機) < 256MCPU消耗 < 1000ms請嚴格按要求輸出,不要畫蛇添足地打印類似:“請您輸入...” 的多余內容。所有代碼放在同一個源文件中,調試通過后,拷貝提交該源碼。注意:不要使用package語句。不要使用jdk1.7及以上版本的特性。注意:主類的名字必須是:Main,否則按無效代碼處理。 package com.sihai.wujie;import java.util.Arrays; import java.util.Scanner;public class _4 { public static char[] arr = new char[15]; public static char[] ch; public static String src = new String(); public static int count=0; public static boolean vis[]; public static void main(String[] args) { Scanner input=new Scanner(System.in); src = input.next(); arr = src.toCharArray(); Arrays.sort(arr); vis = new boolean[arr.length]; ch = new char[arr.length]; dfs(0,src); } private static void dfs(int n, String src) { if(n == arr.length) { if(src.equals(String.valueOf(ch))) { System.out.println(count); } count++; return; } for(int i=0;i<arr.length;i++) { if(!vis[i]) { vis[i] = true; ch[n] = arr[i]; dfs(n+1,src); vis[i] = false; } } } }

總結

以上是生活随笔為你收集整理的蓝桥杯java第五届决赛第四题--排列序数的全部內容,希望文章能夠幫你解決所遇到的問題。

如果覺得生活随笔網站內容還不錯,歡迎將生活随笔推薦給好友。