目錄
ASCII 值
問題陳述
問題解釋
解決方案 1 使用頻率向量
演算法
範例
輸出
上述程式碼的複雜性
解決方案 2 使用內建排序功能的解決方案
結論
首頁 後端開發 C++ 按字元的ASCII值對字串進行排序

按字元的ASCII值對字串進行排序

Sep 07, 2023 pm 08:29 PM
字元 ascii 排序

按字元的ASCII值對字串進行排序

ASCII 值

ASCII(美國資訊交換標準代碼)是電腦和互聯網上文件資料最常見的字元編碼格式。在標準 ASCII 編碼資料中,256 個字母、數字或特殊附加字元和控制代碼都有唯一值。

問題陳述

現在,在這個問題中,我們需要根據字元的 ASCII 值按升序找到排序後的字串,其中該字串將是用戶給我們的輸入。讓我們看看應該如何解決這個問題。

讓我們嘗試借助一些範例來理解這個問題。

輸入 - s = "$%7wjk()"

輸出 - “$%()7jkw”

說明 - 給定字串的字元的 ASCII 值如下 -

$ -> 36
% -> 37
( -> 40
) -> 41
7 -> 55
j -> 106
k -> 107
w -> 119
登入後複製

因此,依照 ASCII 碼值的遞增順序,字串將變成「$%()7jkw」

輸入 - s = "#m 0f )nk"

輸出 - “#)0fkmn”

說明 - 給定字串的字元的 ASCII 值如下 -

(space) -> 32
# -> 35
) -> 41
0 -> 48
f -> 102
k -> 107
m -> 109
n -> 110
登入後複製

因此,依照 ASCII 碼值的遞增順序,字串將變成「#)0fkmn」

問題解釋

讓我們嘗試了解問題並找到解決方案。我們知道 ASCII 表中有 256 個字符,其中每個字符都有唯一的值或位置。所以我們的基本目標是對字元進行對應的排序。我們可以透過使用可用於實現我們的目標的外部函數來使用內建排序函數。另一種方法是建立頻率向量並將每個字元的頻率儲存在該數組中。使用這個頻率向量和 ASCII 值,我們可以獲得新的字串。

解決方案 1 使用頻率向量

演算法

  • 建立一個大小為 256 的頻率向量,因為 ASCII 表中的字元總數為 256,並以零開始整個向量

  • 運行循環來儲存給定字串的每個字元的頻率

  • #現在定義一個原本為空的輸出字串

  • 運行另一個循環來遍歷頻率向量,因此我們可以透過對第 i 個位置Frequency_vector[i]進行類型轉換來獲得輸出字串

  • 傳回輸出字串作為最終結果

範例

以下是上述方法的 C 程式實作:

#include <bits/stdc++.h>
using namespace std;
// Function to Sort the string as per ASCII values of the characters
string Helper(string s){
    // Define the size of the given string
	int size = s.length();
	// Define a frequency vector of size 256, which is the same as the size of the characters as per the ASCII table, and initiate the value of the vector as 0
	vector<int> v(256, 0);
	// Run a loop to count the frequency of each character of the string
	for (int i = 0; i < size; i++) {
		v[s[i]]++;
	}	
	// Declare a string, initially empty, to find the final output
	string ans = "";
	// Run another loop to get the final output in accordance with the ASCII table
	for (int i = 0; i < 256; i++) {
		for (int j = 0; j < v[i]; j++)
		// Typecast the integer value to the character value to include it in the loop
			ans = ans + (char)i;
	}
	// Return the final output
	return ans;
}
int main(){
    // Give input as a string by the user
	string s = "$%7wjk()";
	// Call Helper function to perform the remaining tasks
	cout<< "The sorted string as per ASCII values of the characters is: " << Helper(s);
	return 0;
}
登入後複製

輸出

The sorted string as per ASCII values of the characters is: $%()7jkw
登入後複製
登入後複製

上述程式碼的複雜性

  • 時間複雜度 - O(n);其中 n 是字串的大小。這裡,實際的時間複雜度是O(n * 256),但我們可以將其視為O(n),因為256 可以視為常數,例如k,而O(k * n) 僅視為O(n )。

  • 空間複雜度 - O(256);因為這裡唯一佔用的額外空間是頻率陣列的空間,其大小為256。

解決方案 2 使用內建排序功能的解決方案

演算法

  • 定義一個外部比較函數,用於排序函數中,根據 ASCII 值對字元進行排序,即傳回 int 型別轉換值小於其他字元的字元。

  • 現在,在輔助函數中使用內建排序函數並使用額外參數(比較函數)來正確取得順序。

  • 呼叫輔助函數並取得最終的字串輸出。

範例

#include "bits/stdc++.h"
using namespace std;
// Comparison Function to sort the string as per ASCII values of the characters
bool comparison(char ch1, char ch2){ 
    return int(ch1) <= int(ch2);
}
// Function to sort the string as per ASCII values of the characters
string Helper(string s){
	// Sort the string s with the help of the inbuilt function sort()
	sort(s.begin(), s.end(), comparison);
	// Return the final output string s
	return s;
}
int main(){
    // Give input as a string by the user
	string s = "$%7wjk()";
	// Call Helper function to perform the remaining tasks
	cout<< "The sorted string as per ASCII values of the characters is: " << Helper(s);
	return 0;
}
登入後複製

輸出

The sorted string as per ASCII values of the characters is: $%()7jkw
登入後複製
登入後複製

上述程式碼的複雜性

  • 時間複雜度:O(log(n));眾所周知,內建排序函數需要 O(n * log(n)) 時間來執行程式碼。在這種方法中,我們透過使用附加比較函數來使用內建排序函數,該比較函數將根據該函數對字元進行排序。

  • 空間複雜度:O(1);在上面的程式碼中,我們沒有在某些資料結構中儲存任何變數。

結論

在本文中,根據字元的 ASCII 值按升序查找排序後的字串。我們可以透過兩種方法來解決這個問題。首先,我們可以製作一個大小為256(與ASCII表中的字元數相同)的頻率向量,並儲存每個字元的所有頻率,然後從後面遍歷就可以得到所需的字串。另一種方法可以藉助內建排序函數,並藉助排序函數中傳遞的額外參數。

以上是按字元的ASCII值對字串進行排序的詳細內容。更多資訊請關注PHP中文網其他相關文章!

本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn

熱AI工具

Undresser.AI Undress

Undresser.AI Undress

人工智慧驅動的應用程序,用於創建逼真的裸體照片

AI Clothes Remover

AI Clothes Remover

用於從照片中去除衣服的線上人工智慧工具。

Undress AI Tool

Undress AI Tool

免費脫衣圖片

Clothoff.io

Clothoff.io

AI脫衣器

Video Face Swap

Video Face Swap

使用我們完全免費的人工智慧換臉工具,輕鬆在任何影片中換臉!

熱工具

記事本++7.3.1

記事本++7.3.1

好用且免費的程式碼編輯器

SublimeText3漢化版

SublimeText3漢化版

中文版,非常好用

禪工作室 13.0.1

禪工作室 13.0.1

強大的PHP整合開發環境

Dreamweaver CS6

Dreamweaver CS6

視覺化網頁開發工具

SublimeText3 Mac版

SublimeText3 Mac版

神級程式碼編輯軟體(SublimeText3)

如何在Windows 11/10中按拍攝日期對照片進行排序 如何在Windows 11/10中按拍攝日期對照片進行排序 Feb 19, 2024 pm 08:45 PM

本文將介紹如何在Windows11/10中根據拍攝日期對圖片進行排序,同時探討如果Windows未按日期排序圖片應該如何處理。在Windows系統中,合理整理照片對於方便尋找影像檔案至關重要。使用者可以根據不同的排序方式(如日期、大小和名稱)來管理包含照片的資料夾。此外,還可以根據需要設定升序或降序排列,以便更靈活地組織文件。如何在Windows11/10中按拍攝日期對照片進行排序要按在Windows中拍攝的日期對照片進行排序,請執行以下步驟:打開圖片、桌面或放置照片的任何資料夾在功能區選單中,單

如何在Outlook中按寄件者、主題、日期、類別、大小對電子郵件進行排序 如何在Outlook中按寄件者、主題、日期、類別、大小對電子郵件進行排序 Feb 19, 2024 am 10:48 AM

Outlook提供了許多設定和功能,可協助您更有效地管理工作。其中之一是排序選項,可讓您根據需要對電子郵件進行分類。在這個教學中,我們將學習如何利用Outlook的排序功能,根據寄件者、主題、日期、類別或大小等條件對電子郵件進行整理。這將讓您更輕鬆地處理和查找重要訊息,提高工作效率。 MicrosoftOutlook是一個功能強大的應用程序,可以輕鬆地集中管理您的電子郵件和日曆安排。您可以輕鬆地發送、接收和組織電子郵件,而內建的日曆功能也讓您能夠輕鬆追蹤您即將面臨的活動和約會。如何在Outloo

PHP開發:如何實作表格資料排序與分頁功能 PHP開發:如何實作表格資料排序與分頁功能 Sep 20, 2023 am 11:28 AM

PHP開發:如何實現表格資料排序和分頁功能在進行Web開發中,處理大量資料是一項常見的任務。對於需要展示大量資料的表格,通常需要實現資料排序和分頁功能,以提供良好的使用者體驗和最佳化系統效能。本文將介紹如何使用PHP實作表格資料的排序和分頁功能,並給出具體的程式碼範例。排序功能實作在表格中實作排序功能,可以讓使用者根據不同的欄位進行升序或降序排序。以下是一個實作表格

C++程式:按字母順序重新排列單字的位置 C++程式:按字母順序重新排列單字的位置 Sep 01, 2023 pm 11:37 PM

在這個問題中,一個字串被當作輸入,我們必須按字典順序對字串中出現的單字進行排序。為此,我們為字串中的每個單字(之間用空格區分)分配一個從1開始的索引,並以排序索引的形式獲得輸出。 String={“Hello”,“World”}“Hello”=1“World”=2由於輸入字串中的單字已按字典順序排列,因此輸出將列印為“12”。讓我們看看一些輸入/結果場景-假設輸入字串中的所有單字都相同,讓我們看看結果-Input:{“hello”,“hello”,“hello”}Result:3獲得的結

正確在matplotlib中顯示中文字元的方法 正確在matplotlib中顯示中文字元的方法 Jan 13, 2024 am 11:03 AM

在matplotlib中正確地顯示中文字符,是許多中文使用者常常遇到的問題。預設情況下,matplotlib使用的是英文字體,無法正確顯示中文字元。為了解決這個問題,我們需要設定正確的中文字體,並將其應用到matplotlib中。以下是一些具體的程式碼範例,幫助你正確地在matplotlib中顯示中文字元。首先,我們需要導入需要的函式庫:importmatplot

Java中的Arrays.sort()方法如何依照自訂比較器對陣列進行排序? Java中的Arrays.sort()方法如何依照自訂比較器對陣列進行排序? Nov 18, 2023 am 11:36 AM

Java中的Arrays.sort()方法如何依照自訂比較器對陣列進行排序?在Java中,Arrays.sort()方法是一個非常有用的方法,可以對陣列進行排序。預設情況下,方法會依照升序排序。但是有時候,我們需要依照自己定義的規則來對陣列進行排序。這時,就需要用到自訂比較器(Comparator)。自訂比較器是一個實作了Comparator介面的類,

wps怎麼排序成績高低 wps怎麼排序成績高低 Mar 20, 2024 am 11:28 AM

在我們的工作中,常常會用到wps軟體,wps軟體處理資料的方式方法是非常多的,而且函數功能也是非常強大的,我們常用函數來求平均值,求總和等,可以說只要是統計數據能用的方法,wps軟體庫裡都已經為大家準備好了,下面我們要介紹的是wps怎麼排序成績高低的操作步驟,看完以後大家可以藉鑑經驗。 1.先開啟需要排名的表格。如下圖所示。  2、然後輸入公式=rank(B2,B2:B5,0),一定要輸入0。如下圖所示。  3、輸入完公式以後,按下電腦鍵盤上的F4鍵,這一步驟操作是為了讓相對引用變成絕對引用。

快速了解 PHP 中的 ASCII 數值轉換 快速了解 PHP 中的 ASCII 數值轉換 Mar 28, 2024 pm 06:42 PM

PHP中的ASCII數值轉換是程式設計中常會遇到的問題。 ASCII(AmericanStandardCodeforInformationInterchange)是一種用於將字元轉換為數字的標準編碼系統。在PHP中,我們經常需要透過ASCII碼來實現字元和數字之間的轉換。本文將介紹如何在PHP中進行ASCII數值轉換,並給予具體的程式碼範例。一、將字符

See all articles