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

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

Java數(shù)組棧實(shí)現(xiàn)字符串轉(zhuǎn)換和增長(zhǎng)

Java數(shù)組棧實(shí)現(xiàn)字符串轉(zhuǎn)換和增長(zhǎng)

浮云間 2023-12-13 14:35:43
我正在嘗試使用數(shù)組和字符串緩沖區(qū)來(lái)實(shí)現(xiàn)堆棧。讓我困惑的是如何正確確定字符串的大小而不聚集字符串中的數(shù)組元素。增長(zhǎng)應(yīng)該使我的緩沖區(qū)的容量加倍(我嘗試使用 Ensurecapacity 來(lái)實(shí)現(xiàn))。對(duì)于轉(zhuǎn)換,我將數(shù)組中的元素附加到緩沖區(qū),但正如已經(jīng)提到的,現(xiàn)在知道如何在不丟失數(shù)組元素的真正含義的情況下執(zhí)行此操作。    public class Stack {    private int[] buffer;    private int size;    public Stack(int capacity) {        //TODO        buffer = new int [capacity];        size =0;    }    public String toString() {        StringBuffer converter = new StringBuffer();  //initializing buffer        int i=0; //        while(i<=size) { //while loop let's us append the elements of the array into our stringbuffer            converter.append(buffer[i]+ " ");        }            String wanted = converter.toString(); //converting the buffer to a string            return wanted;         }     private void grow() {        //TODO        StringBuffer doubler = new StringBuffer();        doubler.append(toString()); //adding our string into the new buffer        int l = doubler.length();        doubler.ensureCapacity(l-1); //ensure capacity(if the min argument is smaller than the actual capacity)    }                                //will take 2*min arg +2 as new capacity}
查看完整描述

2 回答

?
弒天下

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

不需要使用StringBufferingrow()方法。

grow()方法中,創(chuàng)建一個(gè)具有2*buffer.length容量的臨時(shí)數(shù)組,迭代buffer并將元素復(fù)制到臨時(shí)數(shù)組,buffer使用臨時(shí)數(shù)組進(jìn)行更新。


查看完整回答
反對(duì) 回復(fù) 2023-12-13
?
鳳凰求蠱

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

不確定你的grow函數(shù)在做什么,但如果你想增加你的函數(shù)的大小buffer,你必須創(chuàng)建一個(gè)新數(shù)組 - 因?yàn)閿?shù)組無(wú)法調(diào)整大小 - 并將舊數(shù)據(jù)復(fù)制到新數(shù)組。然后將緩沖區(qū)重新分配給新數(shù)組:


private void grow() {

    int [] temp = new int[buffer.length * 2];

    for (int i = 0; i < size; i++) {

        temp[i] = buffer[i];

    }

    buffer = temp;

}


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

添加回答

舉報(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)