您好,登錄后才能下訂單哦!
一、模擬酒店房間管理系統,需要如下幾個功能:
1、1 in 房間號 客人名字 入住功能
1、2 out 房間號 退房功能
1、3 search 房間號 查詢房間狀態 如果房間號為-1 則輸出所有房間狀態
1、4 quit 或 exit 退出
提示:酒店所有的房間用二維數組來實現
代碼實現如下:
import java.util.Scanner; public class HotelDemo { //寫在類里面,則每個方法都可以訪問到,避免了參數傳遞的繁瑣; static int h=5,w=10; static String[][] rooms=new String[5][10]; public static void main(String[] args) { @SuppressWarnings("resource") Scanner s=new Scanner(System.in); while(true){ System.out.println("請輸入 in,out,search,quit:"); String temp=s.next(); int room=0; if("in".equals(temp)){//防止出現空指針異常; System.out.println("輸入房間號:"); room=s.nextInt(); System.out.println("輸入名字:"); String name=s.next(); if(in(room,name)) System.out.println("入住完成!"); System.out.println("room"+room+"name"+name); }else if("out".equals(temp)){ System.out.println("輸入房間號:"); room=s.nextInt(); if(out(room)) System.out.println("退房完成!"); System.out.println("out"+room); }else if("search".equals(temp)){ System.out.println("輸入房間號(-1代表全部):"); room=s.nextInt(); search(room); }else if("quit".equals(temp)||"exit".equals(temp)){ break; }else{ System.out.println("命令錯誤!"); } } } private static boolean search(int room) { if(room==-1){ //打印所有的信息; for(int i=0;i<h;i++){ for(int j=0;j<w;j++){ int room2=(i+1)*100+j+1; System.out.print(room2+"\t"); } System.out.println(); for(int k=0;k<w;k++){ System.out.print(rooms[i][k]==null?"empty":rooms[i][k]); System.out.print("\t"); } System.out.println(); System.out.println(); } return true; }else{ int r=room/100-1; int c=room%100-1; if(r<0||r>=h||c<0||c>=w){ System.out.println("房間號錯誤!"); return false; } System.out.println(rooms[r][c]==null?"empty":rooms[r][c]); return true; } } private static boolean out(int room) { int r=room/100-1; int c=room%100-1; if(r<0||r>=h||c<0||c>=w){ System.out.println("房間號錯誤!"); return false; } if(rooms[r][c]==null||"".equals(rooms[r][c])){// System.out.println("此房間沒有人!"); return false; } rooms[r][c]=null; return true; } private static boolean in(int room, String name) { int r=room/100-1; int c=room%100-1; if(r<0||r>=h||c<0||c>=w){ System.out.println("房間號錯誤!"); return false; } if(rooms[r][c]!=null){// System.out.println("此房間已經有人!"); return false; } rooms[r][c]=name; return true; } }
二、螺旋矩陣 例
import java.util.Scanner; public class SpiralSquare01{ public static void main(String[] args) { @SuppressWarnings("resource") Scanner s=new Scanner(System.in); System.out.println("請輸入螺旋方陣的長"); int indexY=s.nextInt(); System.out.println("請輸入螺旋方陣的寬"); int indexX=s.nextInt(); if(indexX<=0||indexY<=0){ System.out.println("輸入的數字不合法!"); return; } int[][] square=new int[indexX][indexY]; int x=0; int y=0; for(int i=1;i<=indexX*indexY;){ while(y<square[x].length-1&&square[x][y+1]==0){ square[x][y++]=i++; } while(x<square.length&&square[x][y]==0){ square[x++][y]=i++; } while(y>0&&square[x-1][y-1]==0){ square[x-1][--y]=i++; } --x; while(x>1&&square[x-1][y]==0){ square[--x][y]=i++; } y++; } for(int i=0;i<square.length;i++){ for(int j=0;j<square[i].length;j++){ System.out.print(square[i][j]+"\t"); } System.out.println(); } } }
運行結果:
三、經典數學問題:百雞問題的變形
題目描述:有36個人,36塊磚,每人搬了一次,正好搬完。其中男每人每次搬4塊,女每人每次搬3塊,小孩兩人每次搬一塊。問 男、女、小孩各多少人?
public class TestBrick { public static void main(String[] args) { int manNum=0; int womanNum=0; for(int i=0;i<=9;i++){ for(int j=0;j<12;j++){ if(((i*4+j*3+(36-i-j)/2)==36)&&((36-i-j)%2==0)){ //注意:孩子的人數必須是偶數,否則會出現一個孩子一次也沒有搬的情況,不符合題意 manNum=i; womanNum=j; System.out.println("男的的人數是"+manNum); System.out.println("女的的人數是"+womanNum); System.out.println("孩子的人數是"+(36-manNum-womanNum)); } } } } }
四、倒計時的算法:輸入一個秒數,要求轉換為XX小時XX分XX秒的格式輸出出來
import java.util.Scanner; public class TestTime { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub @SuppressWarnings("resource") Scanner s=new Scanner(System.in); System.out.println("請輸入秒數:"); int second =s.nextInt(); int hour=second/3600; int minite=second%3600/60; int sec=second%60; System.out.println("轉換后為:"+hour+"小時"+minite+"分"+sec+"秒"); } }
五、密碼的自動生成器:密碼由大寫字母/小寫字母/數字組成,生成六位隨機密碼;
//密碼的自動生成器:密碼由大寫字母/小寫字母/數字組成,生成六位隨機密碼; import java.util.Random; public class TestPassword { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub char[] pardStore=new char[62]; //把所有的大寫字母放進去 for(int i=0;i<20;i++){ pardStore[i]=(char)('A'+i); } //把所有的小寫字母放進去 for(int i=26;i<52;i++){ pardStore[i]=(char)('a'+i); } //吧0到9放進去 for(int i=52;i<62;i++){ pardStore[i]=(char)('0'+(i-52)); } //生成6位隨機密碼 Random r=new Random(); for(int i=0;i<6;i++){ int n=r.nextInt(62); System.out.print(pardStore[n]); } } }
六、寫一個彩票的生成代碼: 1-33隨機選7個不重復的數字;
import java.util.Random; //寫一個彩票的生成代碼: 1-33隨機選7個不重復的數字; public class TestLuckyTicket { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub int[] luckTickets=new int[7]; Random r=new Random(); for(int i=0;i<luckTickets.length;i++){ luckTickets[i]=r.nextInt(8)+1; for(int j=0;j<i;j++){ if(luckTickets[i]==luckTickets[j]){ i--; break; } } } for(int i=0;i<luckTickets.length;i++){ System.out.print(luckTickets[i]+","); } } }
七、定義一個字符串變量String str="床前明月光,疑是地上霜。舉頭望明月,低頭思故鄉。"。
打印成如下格式的:
低 舉 疑 床
頭 頭 是 前
思 望 地 明
故 明 上 月
鄉 月 霜 光
。 , 。 ,
public class TestPoet { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub String str="床前明月光,疑是地上霜。舉頭望明月,低頭思故鄉。"; char[] poet=str.toCharArray(); int l=18; boolean flag=true; int i=0; while(flag){ for(int j=l;j>=(0+i);){ System.out.print(poet[j]); j=j-6; } System.out.println(); l++; i++; if(l==24){flag=false;} } } }
八、九宮格的輸出:九宮格就是每一行,每一列,斜著的一列和反斜著的一列的所在的數字之和均相等;最基本的是三行三列=9格就是很出名的九宮格;還可以推廣到5*5=25個格;只要行和列的個數均相等并且是奇數就可以;
import java.util.Scanner; public class JiuGongGe { /** * @param args */ public static void main(String[] args) { // TODO Auto-generated method stub @SuppressWarnings("resource") Scanner s=new Scanner(System.in); System.out.println("請輸入一個大于等于3的奇數"); int length=s.nextInt(); if(length<3||length%2==0){ System.out.println("輸入的數字不合法!"); return; } int[][] nineTable=new int[length][length]; int indexX=0; int indexY=0; indexY=(nineTable.length-1)/2; nineTable[indexX][indexY]=1; for(int i=1;i<nineTable.length*nineTable.length;i++){ indexX--; indexY++; if(indexY>=nineTable.length&&indexX>=0){ indexY=0; }else if(indexX<0&&indexY<nineTable.length){ indexX=nineTable.length-1; }else if(indexY>=nineTable.length&&indexX<0){ indexY--; indexX=indexX+2; }else if(nineTable[indexX][indexY]!=0){ indexY--; indexX=indexX+2; } nineTable[indexX][indexY]=i+1; } for(int i=0;i<nineTable.length;i++){ for(int j=0;j<nineTable[i].length;j++){ System.out.print(nineTable[i][j]+" "); } System.out.println(); System.out.println(); } } }
總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作能帶來一定的幫助,如果有疑問大家可以留言交流,謝謝大家對億速云的支持。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。