[轉載] 【Java】將一個字符串的字符排序,按ASCII表的順序從小到大

參考鏈接: 在Java中搜索字符串中的字符和子字符串

將一個字符串的字符按ASCII表的順序從小到大排序,如將字符串“asdafxcvMADb”排序為“ADMaabcdfsvx”

?

?

算法的基本思想: 先將字符串轉化為一個char類型的數組,來進行存儲(因Java中的字符串并不像C++中那樣直接使用數組存儲)。 之后按照歸并排序的方法,將char數組中的內容按從小到大排序。歸并排序是一種穩定的排序算法,而且可以將算法的時間復雜度提高到O(nlgn)。?

廢話不多說,直接上代碼:?

public class Demo {

? ? public static void main(String[] args){

? ? ? ? Demo demo=new Demo();

? ? ? ? String string="asdafxcvMADb";

? ? ? ? demo.sortByASCII(string);

? ? }

?

? ? public void sortByASCII(String str){

? ? ? ? char []array=str.toCharArray();? ?//將一個簡單的字符串中的內容轉化為char數組

? ? ? ? sort(array);

? ? ? ? for(char s:array)? ? ? ? ? //輸出

? ? ? ? ? ? System.out.print(s);

? ? }

?

? ? public static void sort(char []arr){

? ? ? ? char []temp = new char[arr.length];? ? //在排序前,先建好一個長度等于原數組長度的臨時數組,避免遞歸中頻繁開辟空間

? ? ? ? sort(arr,0,arr.length-1,temp);

? ? }

? ? private static void sort(char[] arr,int left,int right,char []temp){

? ? ? ? if(left<right){

? ? ? ? ? ? int mid = (left+right)/2;

? ? ? ? ? ? //遞歸的方法

? ? ? ? ? ? sort(arr,left,mid,temp);? ? ? ? //左邊歸并排序,使得左子序列有序

? ? ? ? ? ? sort(arr,mid+1,right,temp);//右邊歸并排序,使得右子序列有序

? ? ? ? ? ? merge(arr,left,mid,right,temp);//將兩個有序子數組合并操作

? ? ? ? }

? ? }

? ? private static void merge(char[] arr,int left,int mid,int right,char[] temp){

? ? ? ? int i = left;? ? ? ? ? //左序列指針

? ? ? ? int j = mid+1;? ? ? ? //右序列指針

? ? ? ? int t = 0;? ? ? ? ? ?//臨時數組指針

? ? ? ? while (i<=mid && j<=right){

? ? ? ? ? ? if(arr[i]<=arr[j])

? ? ? ? ? ? ? ? temp[t++] = arr[i++];

? ? ? ? ? ? else

? ? ? ? ? ? ? ? temp[t++] = arr[j++];

? ? ? ? }

? ? ? ? while(i<=mid){? ? ? ? ? ? ? ?//將左邊剩余元素填充進temp中

? ? ? ? ? ? temp[t++] = arr[i++];

? ? ? ? }

? ? ? ? while(j<=right){? ? ? ? ? ? //將右序列剩余元素填充進temp中

? ? ? ? ? ? temp[t++] = arr[j++];

? ? ? ? }

? ? ? ? t = 0;

? ? ? ? //將temp中的元素全部拷貝到原數組中

? ? ? ? while(left <= right){

? ? ? ? ? ? arr[left++] = temp[t++];

? ? ? ? }

? ? }

}

?

?

鑒于代碼中的注釋也比較清楚,這里也不多說。

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/news/540207.shtml
繁體地址,請注明出處:http://hk.pswp.cn/news/540207.shtml
英文地址,請注明出處:http://en.pswp.cn/news/540207.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

如果只做前端驗證的話,談jjdd.com的看照片功能。

如果你在上海&#xff0c;并且坐過地鐵的話&#xff0c;你肯定知道jjdd.com。 這個網站和百合&#xff0c;世紀佳緣類似&#xff0c;都是交朋友的性質。 在jjdd.com中有個很重要的功能&#xff1a;如果你上傳的照片比你想看的人少的話&#xff0c;你是不能看她的照片的。 例如如…

[轉載] 快速學習-Mybatis框架概述

參考鏈接&#xff1a; Java在競爭性編程中的快速I/O 第1章 框架概述 1.1 什么是框架 1.1.1 什么是框架 框架&#xff08;Framework&#xff09;是整個或部分系統的可重用設計&#xff0c;表現為一組抽象構件及構件實例間交互的方法;另一種定義認為&#xff0c;框架是可被…

3、MySQL的數據類型介紹

上一章節內容主要介紹了一些MySQL中對表和庫的增刪改查操作&#xff0c;對于上一章中對與表中字段的一些定義進行說明&#xff0c;本章主要介紹關于數據庫類型的一些定義。一、概述&#xff1a;MySQL數據庫中的數據大致可以分為以下幾類&#xff0c;從而實現數據庫在操作的時候…

[轉載] 必須要會回答的Java面試題(字符串篇)

參考鏈接&#xff1a; 比較Java中的兩個字符串String 最近很多學習java的小白問我字串相關的問題&#xff0c;覺得很有必要整理下&#xff0c;以方便初學者理解字符串以及應對今后面試中考官的提問。 如果你是有幾年Java開發經驗&#xff0c;可以根據目錄選擇性的閱讀以下內…

[轉載] java如何實現一個字符串的反轉和替換

參考鏈接&#xff1a; 反轉Java中的字符串String 一、java字符串的反轉 1.利用java字符串的拼接實現字符串的反轉&#xff0c;代碼如下&#xff1a; public static String reverse(String s){ int lens.length(); String str""; for (int i 0; i < len; i) { …

java 中的instanceof

java 中的instanceof 運算符是用來在運行時指出對象是否是特定類的一個實例。instanceof通過返回一個布爾值來指出&#xff0c;這個對象是否是這個特定類或者是它的子類的一個實例。 用法&#xff1a;result object instanceof class參數&#xff1a;Result&#xff1a;布爾類…

[轉載] 將一個整數型字符串轉換為一個整數

參考鏈接&#xff1a; Java中整數到字符串轉換的不同方法 package com.utl.string; /* * 將一組整數字符串轉換為整數 * 例&#xff1a;"234"轉換為整數型234 * 分析&#xff1a;涉及到許多問題&#xff0c;例如非法輸入&#xff0c;有正負號&#xff0c;是否為空字…

升級PowerShell至4.0版本

為了更好的使用Cmder v1.2&#xff0c;不得不升級PowerShell為4.0。 不知道Cmder的&#xff0c;可以點擊這里&#xff1a;https://github.com/cmderdev/cmder 和 逆天神器 cmder。 Powershell是運行在Windows機器上實現系統和應用程序管理自動化的命令行腳本環境。 需要.NET環境…

[轉載] 字符串太長 pep8_Python f字符串– PEP 498 –文字字符串插值

參考鏈接&#xff1a; 從Java中的字符串中刪除前導零 字符串太長 pep8 Python f-strings or formatted strings are the new way to format strings. This feature was introduced in Python 3.6 under PEP-498. It’s also called literal string interpolation. Python f字符…

備忘(持續更新。。。)

1、在springmvc這個框架里面&#xff0c;創建新的業務邏輯層&#xff0c;dao、service層至少需要一個接口&#xff0c;項目才能跑起來 2、獲取當前用戶桌面路徑 File desktopDir FileSystemView.getFileSystemView() .getHomeDirectory();String desktopPath desktopDir.getA…

[轉載] 字符串操作截取后面的字符串_對字符串的5個必知的熊貓操作

參考鏈接&#xff1a; 修剪Java中的字符串(刪除前導和尾隨空格) 字符串操作截取后面的字符串 We have to represent every bit of data in numerical values to be processed and analyzed by machine learning and deep learning models. However, strings do not usually co…

更改域控制器的計算機名

林功能級別必須為Windows Server 2003及以上 1. netdom computername Server08-1.contoso.com /add:08Server1.contoso.com 2. netdom computername Server08-1.contoso.com /makeprimary:08Server1.contoso.com 3. Restart your computer 4. netdom computername 08Server1.co…

[轉載] Google Java代碼規范

參考鏈接&#xff1a; 使用Java計算文本文件txt中的行數/單詞數/字符數和段落數 原文地址&#xff1a;https://google.github.io/styleguide/javaguide.html GIthub上GoogleCode風格的配置文件&#xff08;支持Eclipse IDE和IntelliJ IDE&#xff09;&#xff1a;https://git…

SQL PASS西雅圖之行——簽證篇

本人有幸通過IT168&itpub的站慶活動http://www.itpub.net/thread-1716961-1-1.html&#xff0c;并應微軟邀請參加了在西雅圖舉辦的The Conference for SQL Server Professionals&#xff08;簡稱SQL-PASS&#xff09;。 SQL-PASS會議計劃于2012年11月6日-9日舉行&#xff0…

[轉載] java8 lambda表達式 List轉為Map

參考鏈接&#xff1a; 使用Lambda表達式檢查字符串在Java中是否僅包含字母 public static void main(String[] args) { List<User> userList new ArrayList<User>(); User user0 new User("han1", "男1", 20); User user1 new User("…

11.python并發入門(part5 event對象)

一、引入event。 每個線程&#xff0c;都是一個獨立運行的個體&#xff0c;并且每個線程的運行狀態是無法預測的。 如果一個程序中有很多個線程&#xff0c;程序的其他線程需要判斷某個線程的運行狀態&#xff0c;來確定自己下一步要執行哪些操作。 threading模塊中的event對象…

[轉載] Java 將字符串首字母轉為大寫 - 利用ASCII碼偏移

參考鏈接&#xff1a; 使用ASCII值檢查Java中的字符串是否僅包含字母 將字符串name 轉化為首字母大寫。普遍的做法是用subString()取第一個字母轉成大寫再與之后的拼接&#xff1a; str str.substring(0, 1).toUpperCase() str.substring(1); 看到一種效率更高的做法&…

俞永福卸任阿里大文娛董事長,改任 eWTP 投資組長

兩天前&#xff08;11月13日&#xff09;&#xff0c;阿里文娛董事長俞永福離職的消息&#xff0c;在互聯網圈炸了鍋。但很快&#xff0c;俞本人就在微博做了澄清&#xff0c;并稱“永遠幸福&#xff0c;我不會離開”。然而就在今天&#xff08;11月15日&#xff09;&#xff0…

[轉載] java提取字符串中的字母數字

參考鏈接&#xff1a; 使用Regex檢查字符串在Java中是否僅包含字母 String str "adsf adS DFASFSADF阿德斯防守對方asdfsadf37《&#xff1f;&#xff1a;&#xff1f;%#&#xffe5;%#&#xffe5;%#$%#$%^><?1234"; str str.replaceAll("[^a-zA-…

snort的詳細配置

前一段一直在做snort入侵檢測系統的安裝以及配置&#xff0c;看了很多的網上資料&#xff0c;也算是總結了下前輩的經驗吧。需要的軟件包&#xff1a;1、httpd-2.2.6.tar.gz2、mysql-5.1.22-rc-linux-i686-icc-glibc23.tar.gz3、php-5.2.4.tar.bz24、acid-0.9.6b23.tar.gz5、ad…