我试着为我正在制作的游戏创造一副牌。为什么我在这里得到了错误的结果?代码应该输出52张卡片中的每一张卡。我在结构方面是新的,但我认为到目前为止,我在这段代码方面做得很好。是的,我知道有更好的方法来做同样的事情,但我是一个初学者,所以不要评判我。
int main()
{
struct Card
{
int value;
char suit;
};
Card cards[52]; //Declaring each unique card
for (int i = 0; i < 52; i++)
{
cards[i].value = i % 13; // 13 values
if (cards[i].value == 1) {
cards[i].value = 1;
}
if (cards[i].value == 2) {
cards[i].value = 2;
}
if (cards[i].value == 3) {
cards[i].value = 3;
}
if (cards[i].value == 4) {
cards[i].value = 4;
}
if (cards[i].value == 5) {
cards[i].value = 5;
}
if (cards[i].value == 6) {
cards[i].value = 6;
}
if (cards[i].value == 7) {
cards[i].value = 7;
}
if (cards[i].value == 8) {
cards[i].value = 8;
}
if (cards[i].value == 9) {
cards[i].value = 9;
}
if (cards[i].value == 10) {
cards[i].value = 10;
}
if (cards[i].value == 11) {
cards[i].value = 10;
}
if (cards[i].value == 12) {
cards[i].value = 10;
}
if (cards[i].value == 13) {
cards[i].value = 10;
}
cards[i].suit = i / 13;// 4 suits
if (cards[i].suit == 1) {
cards[i].suit = 'D';
}
if (cards[i].suit == 2) {
cards[i].suit = 'H';
}
if (cards[i].suit == 3) {
cards[i].suit = 'C';
}
if (cards[i].suit == 4) {
cards[i].suit = 'S';
}
}
for (int count = 0; count < 52; count++) {
cout << cards[count].value;
cout << cards[count].suit;
cout << endl;
}
return 0;
}编辑:
int main()
{
struct Card //struct is a way to store many values on 1 array for example
{
int value;
char suit;
};
Card cards[52]; //Declaring each unique card
for (int i = 0; i < 52; i++)
{
cards[i].value = i % 13; // 13 values
if (cards[i].value == 0) {
cards[i].value = 1;
}
else if (cards[i].value == 1) {
cards[i].value = 2;
}
else if (cards[i].value == 2) {
cards[i].value = 3;
}
else if (cards[i].value == 3) {
cards[i].value = 4;
}
else if (cards[i].value == 4) {
cards[i].value = 5;
}
else if (cards[i].value == 5) {
cards[i].value = 6;
}
else if (cards[i].value == 6) {
cards[i].value = 7;
}
else if (cards[i].value == 7) {
cards[i].value = 8;
}
else if (cards[i].value == 8) {
cards[i].value = 9;
}
else if (cards[i].value == 9) {
cards[i].value = 10;
}
else if (cards[i].value == 10) {
cards[i].value = 10;
}
else if (cards[i].value == 11) {
cards[i].value = 10;
}
else if (cards[i].value == 12) {
cards[i].value = 10;
}
cards[i].suit = i / 13;// 4 suits
if (cards[i].suit == 0) {
cards[i].suit = 'D';
}
else if (cards[i].suit == 1) {
cards[i].suit = 'H';
}
else if (cards[i].suit == 2) {
cards[i].suit = 'C';
}
else if (cards[i].suit == 3) {
cards[i].suit = 'S';
}
}
for (int count = 0; count < 52; count++) {
cout << cards[count].value;
cout << cards[count].suit;
cout << endl;
}
return 0;
}发布于 2020-04-26 21:31:54
问题是
cards[i].suit = i / 13;将产生介于0和3之间的值,而不是代码假设的1和4之间的值。
同样的问题也存在于
cards[i].value = i % 13;它提供的值介于0到12之间,而不是1和13之间。
好的,最新的问题
if (cards[i].value == 0) {
cards[i].value = 1;
}
if (cards[i].value == 1) {
cards[i].value = 2;
}
if ... etc etc应该是
if (cards[i].value == 0) {
cards[i].value = 1;
}
else if (cards[i].value == 1) {
cards[i].value = 2;
}
else if ... etc etc在您的版本中,第一个if语句(如果为真)将值设置为1,然后下一个if语句将为true,并将值设置为2,依此类推。使用else if确保只执行一个if语句。
发布于 2020-04-26 21:41:51
if (cards[i].value == 11) { cards[i].value = 10; } if (cards[i].value == 12) { cards[i].value = 10; } if (cards[i].value == 13) { cards[i].value = 10; }
我相信这些应该代表Q,J和K?不过可能是个错误。
此外,我/ 13将永远在四舍五入。这应该解决诉讼问题:
cardsi.suit =I/ 13;// 4适合if (cardsi.suit == 0) { cardsi.suit = 'D';} if (cardsi.suit == 1) { cardsi.suit = 'H';} if (cardsi.suit == 2) { cardsi.suit = 'C';} if (cardsi.suit == 3) { cardsi.suit = 'S';}
https://stackoverflow.com/questions/61448346
复制相似问题