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

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

如何在Java中使用for循環(huán)編寫最短路徑問題

如何在Java中使用for循環(huán)編寫最短路徑問題

慕婉清6462132 2024-01-17 16:34:29
我創(chuàng)建了一個(gè)動(dòng)作數(shù)組,每個(gè)動(dòng)作都有一個(gè)成本。之后,我實(shí)現(xiàn)了一個(gè) for 循環(huán)來查找成本最低的操作。其次,我必須檢查先決條件,看看可以采取哪些行動(dòng)。問題出在主邏輯中,因?yàn)楫?dāng)我打印操作名稱和獲得的成本時(shí),顯示的是loadPlaneP1(成本較低的那個(gè)),但我通過的參數(shù)getActParameter1()是unloadTruckP2(數(shù)組中最后一個(gè))的參數(shù)。我收到的輸出是Old state parameters are pkg1Location: lhr pkg2Location: lhr truckLocation: cdg planeLocation: lhr cityLocation:londonPRE The first parameter is : southloadPlaneP1POST The first parameter is : southPrecondition satysfied with action name: loadPlaneP1Costs array: [30, 40, 100, 50, 55, 60, 70, 70, 40]ActionID 0The action choosen is loadPlaneP130southState parameters updated are pkg1Location: south pkg2Location: south truckLocation: south planeLocation: cdg cityLocation:paris所以條件不滿足,因?yàn)槲业玫降膮?shù)getActParameter1()與已有的不同loadPlaneP1。為什么會(huì)發(fā)生這種情況?
查看完整描述

1 回答

?
泛舟湖上清波郎朗

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

我在代碼中看到的一個(gè)問題是 for 循環(huán)條件,如果實(shí)際成本不是最小成本,則會(huì)停止循環(huán)。因此,如果在第一次迭代中實(shí)際成本不等于最小成本,則永遠(yuǎn)不會(huì)迭代 for 循環(huán)。我沒有試圖找出你在 for 循環(huán)中做了什么。可能還有更多錯(cuò)誤。


for( int i = 0; i < acts.length -1; i++ ) 

{

   if ( acts[i].getActionCost( ) == getMinValue( costs ) )

   { 

     System.out.println( "PRE The first parameter is : " +  

                        acts[i].getActParameter1() + acts[i].name );


     if ( acts[i].getActParameter1() == "plane" ) 

     {

        System.out.println( "POST The first parameter is : " + 

                            acts[i].getActParameter1() );

        System.out.println( "Precondition satysfied with action name: " + 

                            acts[i].name );


        if ( acts[i].getActParameter1() != state.getStateParameter1() ) 

        {

          state.setStateParameter1( acts[i].getActParameter1() );

        }


        if(acts[i].getActParameter2() != state.getStateParameter2()) 

        {

          state.setStateParameter2( acts[i].getActParameter2() );

        }


        if( acts[i].getActParameter3() != state.getStateParameter3() ) 

        {

          state.setStateParameter3( acts[i].getActParameter3() );

        }


        if( acts[i].getActParameter4() != state.getStateParameter4() ) 

        {

          state.setStateParameter4( acts[i].getActParameter4() );

        }


        if( acts[i].getActParameter5() != state.getStateParameter5() ) 

        {

          state.setStateParameter5( acts[i].getActParameter5() );

        }

    }


    Node child = new Node(state, startNode, acts[i].getActionCost());


    System.out.println( "Costs array: "+  Arrays.toString( costs ) );

    System.out.println( "ActionID" +" " +  i );

    System.out.println( "The action choosen is " + acts[i].name + 

                        acts[i].actionCost + acts[i].getActParameter1() );

    System.out.println( "State parameters updated are " + "pkg1Location: " + 

                        state.getStateParameter1() + " pkg2Location: " +

                        state.getStateParameter2() + " truckLocation: "+ 

                        state.getStateParameter3() + " planeLocation: " + 

                        state.getStateParameter4() + " cityLocation:"+ 

                        state.getStateParameter5());

  }

}   



查看完整回答
反對(duì) 回復(fù) 2024-01-17
  • 1 回答
  • 0 關(guān)注
  • 163 瀏覽

添加回答

舉報(bào)

0/150
提交
取消
微信客服

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

幫助反饋 APP下載

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

公眾號(hào)

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