2012-03-06 44 views
0

我不明白我的問題在這裏。我的名單中關於派別和數量的價值看起來是正確的。但是,我的輸出有問題。給我唯一的數字和字母沒有在他們在什麼派系顯示將字符打印爲std :: cout的數字

正在打印的號碼語句是在底部,像這樣的:

cout << "Your first Card is " 
    << numberBoxListHead_ptr->getNumber() 
    << factionHead_ptr->getLetter() 
    << endl; 

以下是完整的代碼:

#include <iostream> 
#include <conio.h> 
using namespace std; 

//The Class where the List depends on it. 
class NumberBox 
{ 
private: 

    int number; 
    char letter; 

public: 

    NumberBox *next_ptr; 
    void setNumber(int number) 
    { 
     this->number = number; 
    } 

    void setLetter(char letter) 
    { 
     this->letter = letter; 
    } 


    int getNumber() 
    { 
     return number; 
    } 

    char getLetter() 
    { 
     return letter; 
    } 
}; 

int main() 
{ 
    int number[4]; 
    char faction[4]; 

    NumberBox *factionHead_ptr = new NumberBox(); 
    NumberBox *factionBody1_ptr = new NumberBox(); 
    NumberBox *factionBody2_ptr = new NumberBox(); 
    NumberBox *factionBody3_ptr = new NumberBox(); 
    NumberBox *factionTail_ptr = new NumberBox(); 

    NumberBox *numberBoxListHead_ptr = new NumberBox(); 
    NumberBox *numberBoxListBody1_ptr = new NumberBox(); 
    NumberBox *numberBoxListBody2_ptr = new NumberBox(); 
    NumberBox *numberBoxListBody3_ptr = new NumberBox(); 
    NumberBox *numberBoxListTail_ptr = new NumberBox(); 

    cout << "Please give the number for the first Card" << endl; 
    cin >> number[0]; 
    if(number[0] > 0 && number[0] < 13) 
    { 
     numberBoxListHead_ptr->setNumber(number[0]); /* <--- Setting for the first input, which is the number */ 
    } 
    else 
    { 
     cout << " Invalid " << endl; 
     exit(1); 
    } 
    cout << "Please Give the faction for the first Card" << endl; 
    cin >> faction[0]; 
    if(faction [0] == 's' || faction [0] == 'c' || faction [0] == 'h' || faction [0] == 'd') 
    { 
     if(faction[0] == 's') 
     { 
      factionHead_ptr->setLetter('s'); 
     } 
     else if(faction[0] == 'c') 
     { 
      factionHead_ptr->setLetter('c'); 
     } 
     else if(faction[0] == 'h') 
     { 
      factionHead_ptr->setLetter('h'); 
     } 
     else if(faction[0] == 'd') 
     { 
      factionHead_ptr->setLetter('d'); 
     } 
    } 
    else 
    { 
     cout << "Invalid" << endl; 
     exit(1); 
    } 


    cout << "Please give the number for the Second Card" << endl; 
    cin >> number[1]; 
    if(number[1] > 0 && number[1] < 13) 
    { 
     numberBoxListBody1_ptr->setNumber(number[1]); /* <--- Setting for the second input, which is the number */ 
    } 
    else 
    { 
     cout << " Invalid " << endl; 
     exit(1); 
    } 
    cout << "Please Give the faction for the second Card" << endl; 
    cin >> faction[1]; 
    if(faction[1] == 's' || faction[1] == 'c' || faction [1] == 'h' || faction [1] == 'd') 
    { 
     if(faction[1] == 's') 
     { 
      factionHead_ptr->setLetter('s'); 
     } 
     else if(faction[1] == 'c') 
     { 
      factionHead_ptr->setLetter('c'); 
     } 
     else if(faction[1] == 'h') 
     { 
      factionHead_ptr->setLetter('h'); 
     } 
     else if(faction[1] == 'd') 
     { 
      factionHead_ptr->setLetter('d'); 
     } 
    } 
    else 
    { 
     cout << "Invalid" << endl; 
     exit(1); 
    } 
    cout << "Please give the number for the Third Card" << endl; 
    cin >> number[2]; 
    if(number[2] > 0 && number[2] < 13) 
    { 
     numberBoxListBody2_ptr->setNumber(number[2]); /* <--- Setting for the third input, which is the number */ 
    } 
    else 
    { 
     cout << " Invalid " << endl; 
     exit(1); 
    } 
    cout << "Please Give the faction for the Third Card" << endl; 
    cin >> faction[2]; 
    if(faction[2] == 's' || faction[2] == 'c' || faction [2] == 'h' || faction [2] == 'd') 
    { 
     if(faction[2] == 's') 
     { 
      factionHead_ptr->setLetter('s'); 
     } 
     else if(faction[2] == 'c') 
     { 
      factionHead_ptr->setLetter('c'); 
     } 
     else if(faction[2] == 'h') 
     { 
      factionHead_ptr->setLetter('h'); 
     } 
     else if(faction[2] == 'd') 
     { 
      factionHead_ptr->setLetter('d'); 
     } 
    } 
    else 
    { 
     cout << "Invalid" << endl; 
     exit(1); 
    } 
    cout << "Please give the number for the fourth Card" << endl; 
    cin >> number[3]; 
    if(number[3] > 0 && number[3] < 13) 
    { 
     numberBoxListBody3_ptr->setNumber(number[3]); /* <--- Setting for the fourth input, which is the number */ 
    } 
    else 
    { 
     cout << " Invalid " << endl; 
     exit(1); 
    } 
    cout << "Please Give the faction for the fourth Card" << endl; 
    cin >> faction[3]; 
    if(faction[3] == 's' || faction[3] == 'c' || faction [3] == 'h' || faction [3] == 'd') 
    { 
     if(faction[3] == 's') 
     { 
      factionHead_ptr->setLetter('s'); 
     } 
     else if(faction[3] == 'c') 
     { 
      factionHead_ptr->setLetter('c'); 
     } 
     else if(faction[3] == 'h') 
     { 
      factionHead_ptr->setLetter('h'); 
     } 
     else if(faction[3] == 'd') 
     { 
      factionHead_ptr->setLetter('d'); 
     } 
    } 
    else 
    { 
     cout << "Invalid" << endl; 
     exit(1); 
    } 
    cout << "Please give the number for the Fifth Card" << endl; 
    cin >> number[4]; 
    if(number[4] > 0 && number[4] < 13) 
    { 
     numberBoxListTail_ptr->setNumber(number[4]); /* <--- Setting for the fifth input, which is the number */ 
    } 
    else 
    { 
     cout << " Invalid " << endl; 
     exit(1); 
    } 

    cout << "Please Give the faction for the fifth Card" << endl; 
    cin >> faction[4]; 
    if(faction[4] == 's' || faction[4] == 'c' || faction [4] == 'h' || faction [4] == 'd') 
    { 
     if(faction[4] == 's') 
     { 
      factionHead_ptr->setLetter('s'); 
     } 
     else if(faction[4] == 'c') 
     { 
      factionHead_ptr->setLetter('c'); 
     } 
     else if(faction[4] == 'h') 
     { 
      factionHead_ptr->setLetter('h'); 
     } 
     else if(faction[4] == 'd') 
     { 
      factionHead_ptr->setLetter('d'); 
     } 
    } 
    else 
    { 
     cout << "Invalid" << endl; 
     exit(1); 
    } 

    //This would be the list for the value of the card. 

    numberBoxListHead_ptr->next_ptr = numberBoxListBody1_ptr; /* <--- From Head to Body1 */ 
    numberBoxListBody1_ptr->next_ptr = numberBoxListBody2_ptr; /* <--- From Body1 to Body2 */ 
    numberBoxListBody2_ptr->next_ptr = numberBoxListBody3_ptr; /* <--- From Body2 to Body3 */ 
    numberBoxListBody3_ptr->next_ptr = numberBoxListTail_ptr; /* <--- From Body3 to BodyTail */ 

    //This Would be the list for the faction of the card. 

    factionHead_ptr->next_ptr = factionBody1_ptr; /* <--- From Head to Body1 */ 
    factionBody1_ptr->next_ptr = factionBody2_ptr; /* <--- From Body1 to Body2 */ 
    factionBody2_ptr->next_ptr = factionBody3_ptr; /* <--- From Body2 to Body3 */ 
    factionBody3_ptr->next_ptr = factionTail_ptr; /* <--- From Body3 to BodyTail */ 

    int counter; 
    for(counter = 0; counter < 4; counter++) 
    { 
     if(counter == 0) 
     { 
      cout << "Your first Card is " << numberBoxListHead_ptr->getNumber() << factionHead_ptr->getLetter() << endl; 
     } 
     if(counter == 1) 
     { 
      cout << "Your Second Card is " << numberBoxListBody1_ptr->getNumber() << factionBody1_ptr->getLetter() << endl; 
     } 
     if(counter == 2) 
     { 
      cout << "Your third Card is " << numberBoxListBody2_ptr->getNumber() << factionBody2_ptr->getLetter() << endl; 
     } 
     if(counter == 3) 
     { 
      cout << "Your fourth Card is " << numberBoxListBody3_ptr->getNumber() << factionBody3_ptr->getLetter() << endl; 
     } 
     if(counter == 4) 
     { 
      cout << "Your fifth Card is " << numberBoxListTail_ptr->getNumber() << factionTail_ptr->getLetter() << endl; 
     } 
    } 
    getch(); 
} 

回答

3
int getLetter() 

這是錯誤在這種情況下。 letter是一個字符,如果要將其作爲字母打印,請確保返回字符。

char getLetter() { ... } 

如果返回intstd::cout將打印就像它的牌點數它的數值。如果返回一個char,它將打印相應的字符,而不是其數字值。

(你的代碼需要一個嚴重的重構工作。讓函數來處理輸入的西裝,和排名,並重新使用這些功能,然後找出如何做一個循環讀取四張牌。)

+0

哦,謝謝,我沒有注意到,讓我解決它。 – JuanDelCarlos 2012-03-06 11:20:17

+0

只是最後一件事。第二張直到第五張卡片不顯示該信件。 – JuanDelCarlos 2012-03-06 11:23:53

+1

你需要自己調試,代碼很難遵循,因爲它重複了很多,你有一些事情的數組和其他命名變量。所以你需要自己解決。但看看你的代碼,並檢查你是否曾經設置過排名或適合factionBodyX_ptr變量。 – Mat 2012-03-06 11:28:44