JAVA實(shí)現(xiàn)簡(jiǎn)單停車(chē)場(chǎng)系統(tǒng)代碼
JAVA項(xiàng)目中正號(hào)需要一個(gè)停車(chē)收費(fèi)系統(tǒng),就整理出來(lái)給大家分享一下,希望對(duì)大家有所幫助。
<h1 accuse="qTitle" style="margin: 0px; padding: 0px; font-size: 16px; font-stretch: normal; line-height: 26px; font-family: "PingFang SC", "Lantinghei SC", "Microsoft YaHei", arial, 宋體, sans-serif, tahoma; word-break: break-all; position: relative; color: rgb(51, 51, 51);"><pre name="code" class="html">設(shè)停車(chē)場(chǎng)內(nèi)只有一個(gè)可停放n輛汽車(chē)的狹長(zhǎng)通道,且只有一個(gè)大門(mén)可供汽車(chē)進(jìn)出。汽車(chē)在停車(chē)場(chǎng)內(nèi)按車(chē)輛到達(dá)時(shí)間 10
依次由北向南排列(大門(mén)在最南端,最先到達(dá)的第一輛車(chē)停放在車(chē)場(chǎng)的最北端),若車(chē)場(chǎng)內(nèi)已停滿n輛汽車(chē),則后來(lái)的汽車(chē)只能在門(mén)外的便道上等候,一旦有車(chē)開(kāi)走,則排在便道上的第一輛車(chē)即可開(kāi)入;當(dāng)停車(chē)場(chǎng)內(nèi)某輛車(chē)要離開(kāi)時(shí),在它之后開(kāi)入的車(chē)輛必須先退出車(chē)場(chǎng)為它讓路,待該輛車(chē)開(kāi)出大門(mén)外,其它車(chē)輛再按原次序進(jìn)入車(chē)場(chǎng),每輛停放在車(chē)場(chǎng)的車(chē)在它離開(kāi)停車(chē)場(chǎng)時(shí)必須按它停留的時(shí)間長(zhǎng)短交納費(fèi)用。試為停車(chē)場(chǎng)編制按上述要求進(jìn)行管理的模擬程序。
【基本要求】以棧模擬停車(chē)場(chǎng),以隊(duì)列模擬車(chē)場(chǎng)外的便道,按照從終端讀入的輸入數(shù)據(jù)序列進(jìn)行模擬管理。每一組輸入數(shù)據(jù)包括三個(gè)數(shù)據(jù)項(xiàng):汽車(chē)“到達(dá)”或“離去”信息、汽車(chē)牌照號(hào)碼及到達(dá)或離去的時(shí)刻,對(duì)每一組輸入數(shù)據(jù)進(jìn)行操作后的輸出數(shù)據(jù)為:若是車(chē)輛到達(dá),則輸出汽車(chē)在停車(chē)場(chǎng)內(nèi)或便道上的停車(chē)位置;若是車(chē)離去;則輸出汽車(chē)在停車(chē)場(chǎng)內(nèi)停留的時(shí)間和應(yīng)交納的費(fèi)用(在便道上停留的時(shí)間不收費(fèi))。棧以順序結(jié)構(gòu)實(shí)現(xiàn),隊(duì)列以鏈表實(shí)現(xiàn)。
【測(cè)試數(shù)據(jù)】設(shè)n=2,輸入數(shù)據(jù)為:(‘A',1,5),(‘A',2,10),(‘D',1,15),(‘A',3, 20), (‘A',4,25),(‘A',5,30),(‘D',2,35),(‘D',4,40),(‘E',0,0)。每一組輸入數(shù)據(jù)包括三個(gè)數(shù)據(jù)項(xiàng):汽車(chē)“到達(dá)”或“離去”信息、汽車(chē)牌照號(hào)碼及到達(dá)或離去的時(shí)刻,其中,‘A'表示到達(dá);‘D'表示離去,‘E'表示輸入結(jié)束。
【實(shí)現(xiàn)提示】需另設(shè)一個(gè)棧,臨時(shí)停放為給要離去的汽車(chē)讓路而從停車(chē)場(chǎng)退出來(lái)的汽車(chē),也用順序存儲(chǔ)結(jié)構(gòu)實(shí)現(xiàn)。輸入數(shù)據(jù)按到達(dá)或離去的時(shí)刻有序。棧中每個(gè)元素表示一輛汽車(chē),包含兩個(gè)數(shù)據(jù)項(xiàng):汽車(chē)的牌照號(hào)碼和進(jìn)入停車(chē)場(chǎng)的時(shí)刻。</pre><br>
<br>
</h1><h1><a name="t1"></a></h1>
<pre></pre>
<pre name="code" class="java">import java.util.Scanner;
public class tingchechangxitong {
public static void main(String[] args){
Scanner sc = new Scanner(System.in);
System.out.println("請(qǐng)輸入車(chē)庫(kù)大小和每小時(shí)收費(fèi):");
int size = sc.nextInt();
int cost = sc.nextInt();
int p = 0,q = 0,hm,sj,i=0,wz=0,j=0,bwz = 0;
char c;
System.out.print(size + " " + cost);
base [] ck1 = new base[size]; //車(chē)庫(kù)大小一定
base [] ck2 = new base[size];
base [] ck3 = new base[100]; //假設(shè)便道可以放無(wú)限的車(chē)
based(ck1,size);
based(ck2,size);
based(ck3,100);
while(true){
System.out.println("輸入數(shù)據(jù):\n");
c = sc.next().charAt(0);
if(c == 'e'||c == 'E'){
System.out.println("結(jié)束使用");
break;
}
hm = sc.nextInt();
sj = sc.nextInt();
if(c == 'a'||c == 'A')
if(p<size){
ck1[p].hm = hm;
ck1[p].sj = sj;
System.out.println(hm + "號(hào)車(chē)進(jìn)入車(chē)庫(kù)" + (p+1) + "WZ");
p++;
System.out.println("現(xiàn)在車(chē)庫(kù)內(nèi)的車(chē)輛為(從里往外):");
for( i = 0;i<p;i++){
System.out.print(ck1[i].hm + " ");
System.out.println();}
}else{
ck3[q].hm = hm;
ck3[q].sj = sj;
System.out.println(hm + "號(hào)車(chē)進(jìn)入便道"+ (q+1) + "WZ");
q++;
}
if(c == 'd'||c == 'D'){
for(i=0;i<size;i++){
if(ck1[i].hm == hm){
System.out.println(hm + "號(hào)車(chē)離開(kāi)車(chē)庫(kù)"+ (i+1) + "WZ" + "總花費(fèi):" + (sj-ck1[i].sj)*cost);
p--;
wz=i;
break;
}
}
//changeWZ(ck1,wz,p);//
//
ZchangeWZ(ck1,ck2,wz,size-1);//棧實(shí)現(xiàn)
//
System.out.println("現(xiàn)在車(chē)庫(kù)內(nèi)的車(chē)輛為(從里往外):");
for( i = 0;i<p;i++){
System.out.print(ck1[i].hm + " ");
System.out.println();
}
//實(shí)現(xiàn)便道的車(chē)進(jìn)入車(chē)庫(kù)
if(p<size)
{
if(q>0)
{
//for(i=0,j=p;j<size && i<q;i++,j++){
// ck1[j].hm = ck3[i].hm;
ck1[p].hm = ck3[0].hm;
// ck1[j].sj = ck3[i].sj;
ck1[p].sj = ck3[0].sj;
// bwz = i-1;
BDchangeWZ(ck1,ck3,bwz,q);//隊(duì)列實(shí)現(xiàn)
p++;
q--;
System.out.println("便道車(chē)入車(chē)庫(kù)");
System.out.println("現(xiàn)在車(chē)庫(kù)內(nèi)的車(chē)輛為(從里往外):");
for( i = 0;i<p;i++){
System.out.print(ck1[i].hm + " ");
System.out.println();}
}
/*if(q>0){
ck1[size-1].hm = ck3[i].hm;
ck1[j].sj = ck3[i].sj;
bwz = i-1;
BDchangeWZ(ck1,ck3,bwz,q-1);//隊(duì)列實(shí)現(xiàn)
p++;
q--;
}*/
}
if(p==0)
System.out.print("NULL\n");
}
}
}
//
//數(shù)據(jù) 3 3 a 1 1 a 2 2 a 3 3 a 4 4 a 5 5
//
//
/**
* 相應(yīng)函數(shù)
* @param ck
* @param size
*/
//基于base的數(shù)組
public static void based(base[]ck,int size)
{
for(int i=0;i<size;i++)
{
ck[i] = new base();
}
}
/* public static void changeWZ(base[]ck,int w,int p){//直接覆蓋實(shí)現(xiàn)車(chē)輛的出車(chē)庫(kù)
for(int i = w;i<p;i++){
ck[i].hm = ck[i+1].hm;
}
}*/
public static void ZchangeWZ(base[]ck1,base[]ck2,int w,int s){//棧的思想實(shí)現(xiàn)
int i,j;
for( i = s,j = 0;i>w;i--,j++){
ck2[j].hm = ck1[i].hm;
ck2[j].sj = ck1[i].sj;
}//前面的車(chē)讓道
int k = j-1;
for(i = w, j = k;j>=0;i++,j--){
ck1[i].hm = ck2[j].hm;
ck1[i].sj = ck2[j].sj;
}
}
public static void BDchangeWZ(base[]ck1,base[]ck3,int w,int s){//隊(duì)列的思想實(shí)現(xiàn)
int j;
for(j = 0;j<s-1;j++){
ck3[j].hm = ck3[j+1].hm;
ck3[j].sj = ck3[j+1].sj;
// w--;
}//前面的車(chē)進(jìn)入車(chē)庫(kù)
}
}
//基礎(chǔ)類
class base {
int hm;
int sj;
}
</pre><br>
以上就是一個(gè)完整的JAVA停車(chē)系統(tǒng)實(shí)例代碼,希望大家可以用的到
相關(guān)文章
springboot項(xiàng)目中沒(méi)有識(shí)別到y(tǒng)ml文件解決辦法
這篇文章主要給大家介紹了springboot項(xiàng)目中沒(méi)有識(shí)別到y(tǒng)ml文件解決辦法,文中通過(guò)代碼示例給大家講解的非常詳細(xì),對(duì)大家的學(xué)習(xí)或工作有一定的幫助,需要的朋友可以參考下2024-01-01
Spring Boot解決項(xiàng)目啟動(dòng)時(shí)初始化資源的方法
這篇文章主要給大家介紹了關(guān)于Spring Boot如何解決項(xiàng)目啟動(dòng)時(shí)初始化資源的方法,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2018-05-05
Jenkins一鍵打包部署SpringBoot應(yīng)用的方法步驟
本文主要介紹了使用Jenkins一鍵打包部署SpringBoot應(yīng)用的方法步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2021-12-12
Java利用多線程和分塊實(shí)現(xiàn)快速讀取文件
在工作中經(jīng)常會(huì)有接收文件并且讀取落庫(kù)的需求,讀取方式都是串行讀取,所以本文主要為大家介紹一下如何利用多線程和分塊實(shí)現(xiàn)快速讀取文件,希望對(duì)大家有所幫助2023-09-09
解決mybatis 執(zhí)行mapper的方法時(shí)報(bào)空指針問(wèn)題
這篇文章主要介紹了解決mybatis 執(zhí)行mapper的方法時(shí)報(bào)空指針問(wèn)題,具有很好的參考價(jià)值,希望對(duì)大家有所幫助。如有錯(cuò)誤或未考慮完全的地方,望不吝賜教2021-07-07
springcloud3 Sentinel的搭建及案例操作方法
Sentinel是分布式系統(tǒng)流量控制的哨兵,阿里開(kāi)源的一套服務(wù)容錯(cuò)的綜合性解決方案,這篇文章主要介紹了springcloud3 Sentinel的搭建以及案例操作,需要的朋友可以參考下2023-01-01
SpringMVC日期類型參數(shù)傳遞實(shí)現(xiàn)步驟講解
這篇文章主要介紹了SpringMVC日期類型參數(shù)傳遞實(shí)現(xiàn)步驟,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)吧2023-02-02

