第七色在线视频,2021少妇久久久久久久久久,亚洲欧洲精品成人久久av18,亚洲国产精品特色大片观看完整版,孙宇晨将参加特朗普的晚宴

為了賬號(hào)安全,請(qǐng)及時(shí)綁定郵箱和手機(jī)立即綁定
已解決430363個(gè)問(wèn)題,去搜搜看,總會(huì)有你想問(wèn)的

為什么我們?cè)趈ava中使用string.charAt(index)-'a'?

為什么我們?cè)趈ava中使用string.charAt(index)-'a'?

慕勒3428872 2021-08-25 10:18:01
public static void main(String[] args) throws IOException {    BufferedReader br = new BufferedReader(new InputStreamReader(System.in));    String s = br.readLine();    int[] arr = new int[26];    for(int i=0;i<s.length();i++)        arr[s.charAt(i)-'a']++;        int odds = 0;    for(int i=0;i<26;i++)        if(arr[i]%2!=0)            odds++;        if(odds%2==1 || odds==0)        System.out.println("First");    else        System.out.println("Second");}我看到了這段代碼,發(fā)現(xiàn)這部分令人困惑。所以你能告訴我為什么我們要使用這個(gè)以及'a'in 的意義是arr[s.charAt(i)-'a']++;什么?
查看完整描述

2 回答

?
qq_花開花謝_0

TA貢獻(xiàn)1835條經(jīng)驗(yàn) 獲得超7個(gè)贊

這段代碼為字母表中的每個(gè)字母制作了一個(gè)類似直方圖的計(jì)數(shù)器。嘗試打印'a'如下字符:


System.out.println((int)'a'); // Output: 97

每個(gè)char都有一個(gè)對(duì)應(yīng)的 Unicode 值,介于 0 和 65,535 之間。減去'a'(或,97)將字母表中的每個(gè)字母縮放到與arr數(shù)組中的“桶”相對(duì)應(yīng)的 0-26 范圍。下面是一個(gè)例子:


System.out.println('z' - 'a'); // Output: 25 (the last bucket in the array)

System.out.println('a' - 'a'); // Output: 0 (the first bucket in the array)

代碼中的第二個(gè)循環(huán)檢查每個(gè)計(jì)數(shù)的奇偶校驗(yàn)以確定哪些是奇數(shù)。最后,最后的打印條件檢查字母總數(shù)是否出現(xiàn)奇數(shù)。如果這個(gè)總數(shù)0或它本身是奇數(shù),則打印"First",否則"Second"。


使用ato之外的任何字符z或大寫字母嘗試使用此代碼。它會(huì)崩潰,因?yàn)樽址?ASCII 表示超出了數(shù)組的大小,你會(huì)得到一個(gè)IndexOutOfBoundsException.


這是一個(gè)示例程序,顯示了如何構(gòu)建直方圖并通過(guò)加法將其輸出轉(zhuǎn)換回字母:


class Main {

    public static void main(String[] args) {

        String s = "snuffleupagus";

        int[] arr = new int[26];


        for (int i = 0; i < s.length(); i++) {

            arr[s.charAt(i)-'a']++;

        }


        for (int i = 0; i < arr.length; i++) {

            System.out.println((char)(i + 'a') + ": " + arr[i]);

        }

    }

}

輸出:


a: 1

b: 0

c: 0

d: 0

e: 1

f: 2

g: 1

h: 0

i: 0

j: 0

k: 0

l: 1

m: 0

n: 1

o: 0

p: 1

q: 0

r: 0

s: 2

t: 0

u: 3

v: 0

w: 0

x: 0

y: 0

z: 0


查看完整回答
反對(duì) 回復(fù) 2021-08-25
?
梵蒂岡之花

TA貢獻(xiàn)1900條經(jīng)驗(yàn) 獲得超5個(gè)贊

arr由大小為 26 的 int 數(shù)組組成,這也是英文字母表中的字母數(shù)。這個(gè)循環(huán)所做的就是計(jì)算字母的頻率,通過(guò)它們?cè)谧帜副碇械乃饕硎荆?code>arr[0]being 'a'arr[1]being'b'等。

它的技術(shù)細(xì)節(jié)可以簡(jiǎn)單地解釋。s.charAt(i)正在返回char指定位置的實(shí)例i。char在 Java 中,A也可以表示為一個(gè)字節(jié)。減法然后byte從當(dāng)前字符中獲取 'a'的 ASCII 值(表示為 a )i。所以你最終得到的是'a' - 'a' == 0'b' - 'a' == 1, 等等。

請(qǐng)注意,這可能不是計(jì)算字符的最佳方法,因?yàn)樽址赡馨牟粌H僅是小寫字母,例如大寫字母和更多符號(hào)。


查看完整回答
反對(duì) 回復(fù) 2021-08-25
  • 2 回答
  • 0 關(guān)注
  • 414 瀏覽
慕課專欄
更多

添加回答

舉報(bào)

0/150
提交
取消
微信客服

購(gòu)課補(bǔ)貼
聯(lián)系客服咨詢優(yōu)惠詳情

幫助反饋 APP下載

慕課網(wǎng)APP
您的移動(dòng)學(xué)習(xí)伙伴

公眾號(hào)

掃描二維碼
關(guān)注慕課網(wǎng)微信公眾號(hào)