找出在質數位置上的字元的ASCII值的總和
介紹
在本教程中,我們將學習 C 的概念,以求出現在主要位置的字元的 ASCII 值總和。質數位置是指位置為 2、3、5 或任何其他質數的字元。
ASCII(美國資訊交換標準代碼)值是字母、字母、標點符號和編碼中使用的其他字元的唯一數值。它用於與電腦通信,因為電腦無法理解人類語言。
有128個ASCII值,從0到127。大寫和小寫字母有不同的ASCII值。
我們將開發一個C 程式碼來計算位於質數位置的字元的ASCII值。我們使用了字串類別的length()函數來儲存輸入字串的長度。
範例1
There is an string = “Hello” Sum of prime position ASCII value characters = 320
In the above string “Hello” the ASCII value of each character is H = 72 e = 101 l = 108 l = 108 o = 111
在質數位置的字元是“e”,“l”,“o”。將這些素數位置字元的ASCII值相加。
樣本2
Input string = “abcd” Sum = 197
輸入字串「abcd」中的主要位置字元是「b」和「c」。
The ASCII value of input string characters is as listed: a = 97 b = 98 c = 99 d = 100
計算字串中主要位置的字元的 ASCII 值總和。
文法
sqrt() − 這個函式庫函數在數學函式庫中定義,它傳回輸入數字的平方根
sqrt(n)
length() − 這個字串類別庫函數傳回輸入字串的長度,長度是字串中字元的數量。
string_name.length();
範例 1
我們將使用C 程式語言實作一個範例,計算位於輸入字串中質數位置的字元的ASCII值總和。 C 代碼輸入字串為「Hello」。我們首先透過應用識別質數的邏輯來找到輸入字串的所有質數位置。使用for循環找到輸入字串所有字元的ASCII值。將位於質數位置的輸入字串字元的ASCII值求和。
#include <iostream> #include <string> #include <vector> using namespace std; // User-defined function to find the prime positions bool find_prime(int p){ if (p <= 1) { return false; } // loop to check the prime number for (int x = 2; x*x <= p; x++) { if (p % x == 0) { return false; } } return true; } // user-defined function to sum ASCII values of the prime position characters int sum_of_primes(string st) { int sum1 = 0; //variable to store the input string length. int p = st.length(); vector<bool> primes(p+1, false); primes[2] = true; for (int x = 3; x <= p; x += 2) { primes[x] = find_prime(x); } for (int x = 2; x <= p; x++){ if (primes[x] && x <= p){ sum1 += int(st[x-1]); } } return sum1; } // controlling code int main(){ string st = "Hello"; int sum1 = sum_of_primes(st); cout << "Sum of ASCII values of characters at prime positions: " << sum1 << endl; return 0; }
輸出
"Sum of ASCII values of characters at prime positions: 320
Example 2
的翻譯為:範例2
在這裡,我們使用不同的邏輯來實作這個範例。我們先找到質數位置,在main()函數中找到這些ASCII值並相加。
#include <iostream> #include <cmath> using namespace std; bool isNumPrime(int n) { if (n < 2) return false; for (int x = 2; x <= sqrt(n); ++x) { if (n % x == 0) return false; } return true; } int main() { string str = "tutorialspoint"; //std::cout << "Enter a string: "; int s = 0; for (size_t x = 0; x < str.length(); ++x) { if (isNumPrime(x + 1)) { s += static_cast<int>(str[x]); } } cout << "Sum of ASCII values at prime positions: " << s << endl; return 0; }
輸出
Sum of ASCII values at prime position: 665
結論
在本教程中,我們開發了C 程式碼來找到素位置字元的ASCII值的總和。我們使用了字串類別的length()函數來找到參數字串的長度。 ASCII值是預先確定的字母和其他字元的值,用於幫助電腦進行通訊。在本教程中,我們實作了兩個具有不同邏輯的範例,並使用了一些C 函式庫函數。最重要的函式庫函數是length()。這個length()函式庫函數傳回字串的長度。
以上是找出在質數位置上的字元的ASCII值的總和的詳細內容。更多資訊請關注PHP中文網其他相關文章!

熱AI工具

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

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

Undress AI Tool
免費脫衣圖片

Clothoff.io
AI脫衣器

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

熱門文章

熱工具

記事本++7.3.1
好用且免費的程式碼編輯器

SublimeText3漢化版
中文版,非常好用

禪工作室 13.0.1
強大的PHP整合開發環境

Dreamweaver CS6
視覺化網頁開發工具

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

C#和C 的歷史與演變各有特色,未來前景也不同。 1.C 由BjarneStroustrup在1983年發明,旨在將面向對象編程引入C語言,其演變歷程包括多次標準化,如C 11引入auto關鍵字和lambda表達式,C 20引入概念和協程,未來將專注於性能和系統級編程。 2.C#由微軟在2000年發布,結合C 和Java的優點,其演變注重簡潔性和生產力,如C#2.0引入泛型,C#5.0引入異步編程,未來將專注於開發者的生產力和雲計算。

C#和C 的学习曲线和开发者体验有显著差异。1)C#的学习曲线较平缓,适合快速开发和企业级应用。2)C 的学习曲线较陡峭,适用于高性能和低级控制的场景。

C 學習者和開發者可以從StackOverflow、Reddit的r/cpp社區、Coursera和edX的課程、GitHub上的開源項目、專業諮詢服務以及CppCon等會議中獲得資源和支持。 1.StackOverflow提供技術問題的解答;2.Reddit的r/cpp社區分享最新資訊;3.Coursera和edX提供正式的C 課程;4.GitHub上的開源項目如LLVM和Boost提陞技能;5.專業諮詢服務如JetBrains和Perforce提供技術支持;6.CppCon等會議有助於職業

C 通過第三方庫(如TinyXML、Pugixml、Xerces-C )與XML交互。 1)使用庫解析XML文件,將其轉換為C 可處理的數據結構。 2)生成XML時,將C 數據結構轉換為XML格式。 3)在實際應用中,XML常用於配置文件和數據交換,提升開發效率。

C 在現代編程中仍然具有重要相關性。 1)高性能和硬件直接操作能力使其在遊戲開發、嵌入式系統和高性能計算等領域佔據首選地位。 2)豐富的編程範式和現代特性如智能指針和模板編程增強了其靈活性和效率,儘管學習曲線陡峭,但其強大功能使其在今天的編程生態中依然重要。

C 的未來將專注於並行計算、安全性、模塊化和AI/機器學習領域:1)並行計算將通過協程等特性得到增強;2)安全性將通過更嚴格的類型檢查和內存管理機制提升;3)模塊化將簡化代碼組織和編譯;4)AI和機器學習將促使C 適應新需求,如數值計算和GPU編程支持。

1)c relevantduetoItsAverity and效率和效果臨界。 2)theLanguageIsconTinuellyUped,withc 20introducingFeaturesFeaturesLikeTuresLikeSlikeModeLeslikeMeSandIntIneStoImproutiMimproutimprouteverusabilityandperformance.3)

靜態分析在C 中的應用主要包括發現內存管理問題、檢查代碼邏輯錯誤和提高代碼安全性。 1)靜態分析可以識別內存洩漏、雙重釋放和未初始化指針等問題。 2)它能檢測未使用變量、死代碼和邏輯矛盾。 3)靜態分析工具如Coverity能發現緩衝區溢出、整數溢出和不安全API調用,提升代碼安全性。
