2016-05-31 61 views
0

我想覆蓋我的事務數組的第一個元素,當它滿了。所以當我打印數組時,它總是顯示最新的事務。簡單的ATM任務,數組問題。

我認爲問題是在moveTrans方法或findNr方法,但我不知道,我不知道什麼是錯的。

代碼:

import java.util.Scanner; 
import java.util.*; 


public class BankoTest { 

public static void main(String[] args) 
{ 
    Scanner scan = new Scanner(System.in); 

    int amount = 0; 
    int choice = 0; 
    int [] trans = new int[4]; 
    int sum; 
    int balance = 0; 

    while (choice != 4) 
    { 
     choice = menu(); 
     switch(choice) 
     { 
     case 1:// 
      System.out.print("Deposit. Amount? :"); 
      amount = scan.nextInt(); 
      balance = balance + amount; 
      makeTransactions(trans, amount); 
      break; 

     case 2:// 
      System.out.print("Withdra. Amount?"); 
      amount = scan.nextInt(); 
      balance = balance - amount; 
      makeTransactions(trans, -amount); 
      break; 

     case 3: 
      showTransactions(trans, balance); 
      break; 

     case 4: 
      System.out.println("Thank you. "); 
      break; 
     } 

    } 
} 


public static int menu() 
{ 
    Scanner scan = new Scanner(System.in); 
    int choice = 0; 

    System.out.println("1. Deposit "); 
    System.out.println("2. Withdraw "); 
    System.out.println("3. Saldo "); 
    System.out.println("4. End "); 
    System.out.println(); 
    System.out.println("Choice: "); 

    choice = scan.nextInt(); 
    return choice; 
} 

public static void showTransactions(int [] trans, int balance) 
{ 
    System.out.println(); 
    System.out.println("Transactions summary :"); 
    System.out.println(); 

    for(int i = 0; i < trans.length-1; i++) 
    { 
     if(trans[i] == 0) 
     { 
      System.out.print(""); 
     } 

     else 
     { 
      System.out.print(trans[i] + "\n"); 
      balance = balance + trans[i]; 

     } 

    } 
    // Printing saldo. 
    System.out.println(); 
    System.out.println("Current balance: " + balance + " kr" + "\n"); 
    System.out.println(); 

} 


//Puts amount last among the transactions that are stored in the array. Using the findNr method to find the first available spot 
//in the array. moveTrans is used to make room for the new transaction when the array is full. 

public static void makeTransactions(int [] trans, int amount) 
{ 
    int position = findNr(trans); 
    if(position == -1) 
    { 
     moveTrans(trans); 
     position = findNr(trans); 
     trans[position] = amount; 
    } 
    else 
    { 
     trans[position] = amount; 
    } 

} 

public static int findNr(int [] trans) 
{ 
    int position = -1; 

    for(int i = 0; i <= trans.length-1; i++) 
    { 
     if(trans[i] == 0) 
     { 
      position = i; 
      break; 
     } 
    } 
    return position; 
} 

public static void moveTrans(int [] trans) 
{ 
    for(int i = 0; i < trans.length-1; i++) 

     trans[0] = trans[i + 1] ; 
} 
} 
+0

moveTrans必須保證以下findNr不提供-1。那個'trans [0]'也是錯誤的。 –

+0

@JoopEggen,你是什麼意思?我應該改變什麼? – forTheLoveOfJava

回答

0

只是修改單獨下面的方法

public static void makeTransactions(int[] trans, int amount) { 
     int position = findNr(trans); 
     if (position == -1) { 
      moveTrans(trans); 
      position = findNr(trans); 
      trans[position] = amount; 
     } else { 
      if (position != 0 && position == trans.length - 1) { 
      // shift the elements back 
      for (int i = 0; i < position; i++) 
       trans[i] = trans[i] + 1; 
      trans[position - 1] = amount; 
     }else 
      trans[position] = amount; 
     } 

} 
+0

這解決了我的問題。我只是改變了這一行:trans [i] = trans [i] + 1;對此:trans [i] = trans [i + 1];所以它會移動一步而不是添加。 – forTheLoveOfJava

0

請檢查這可能幫助一些東西給你

公共靜態無效的主要(字串[] args){ 掃描程序掃描=新的掃描儀(System.in);

int amount = 0; 
    int choice = 0; 
    int[] trans = new int[4]; 
    int sum; 
    int balance = 0; 

    while (choice != 4) { 

     choice = menu(); 

     switch (choice) { 
     case 1:// 
      System.out.print("Deposit. Amount? :"); 
      amount = scan.nextInt(); 
      balance = balance + amount; 
      makeTransactions(trans, amount); 
      break; 

     case 2:// 
      System.out.print("Withdra. Amount?"); 
      amount = scan.nextInt(); 
      balance = balance - amount; 
      makeTransactions(trans, -amount); 
      break; 

     case 3: 
      showTransactions(trans, balance); 
      break; 

     case 4: 
      System.out.println("Thank you. "); 
      break; 
     } 

    } 
} 

public static int menu() { 
    Scanner scan = new Scanner(System.in); 
    int choice = 0; 

    System.out.println("1. Deposit "); 
    System.out.println("2. Withdraw "); 
    System.out.println("3. Saldo "); 
    System.out.println("4. End "); 
    System.out.println(); 
    System.out.println("Choice: "); 

    choice = scan.nextInt(); 
    return choice; 
} 

public static void showTransactions(int[] trans, int balance) { 
    System.out.println(); 
    System.out.println("Transactions summary :"); 
    System.out.println(); 

    for (int i = 0; i < trans.length - 1; i++) { 
     if (trans[i] == 0) { 
      System.out.print(""); 
     } 

     else { 
      System.out.print(trans[i] + "\n"); 
      // balance = trans[i]; 

     } 

    } 
    // Printing saldo. 
    System.out.println(); 
    System.out.println("Current balance: " + balance + " INR" + "\n"); 
    System.out.println(); 

} 

// Puts amount last among the transactions that are stored in the array. 
// Using the findNr method to find the first available spot 
// in the array. moveTrans is used to make room for the new transaction when 
// the array is full. 

public static void makeTransactions(int[] trans, int amount) { 
    int position = findNr(trans); 

    if (position == -1) { 
     moveTrans(trans); 
     System.out.println("Your transaction limit is over."); 
     // position = findNr(trans); 
     // System.out.println("Position -------> "+position); 
     // trans[position] = amount; 
    } else { 
     trans[position] = amount; 
    } 

} 

public static int findNr(int[] trans) { 
    int position = -1; 

    for (int i = 0; i <= trans.length - 1; i++) { 
     if (trans[i] == 0) { 
      position = i; 
      break; 
     } 
    } 
    return position; 
} 

public static void moveTrans(int[] trans) { 
    System.out.println("------Your Transaction Details----------"); 
    for (int i = 0; i < trans.length; i++) { 

     System.out.println("Transation " + (i + 1) + " :: " + trans[i]); 

     trans[0] = trans[i]; 
    } 
    System.out.println("----------------------------------------"); 
}