C
C#3y ago
Ghost_

❔ Populating an Array with a Loop and then being able to call indexes

I created a 52 card playing deck, and I know the loop works because the output is correct. The problem is all it does is print out all the cards in the deck. It's not populating the deck array with the results outside the loop. The reason why that's a problem is because if I wanted to print the 5th card of the deck (deck[4]) I can't, because the array is still empty outside of the loop. It's possible that you don't use loops and or arrays and or my main method is wrong. I'm still learning. But none of the resources I can find talk about something like this. It either talks about prints the loop (which is what I can do already) or it manually populates an array 1 at a time (which would take up memory, exactly what I am trying to avoid by doing a loop). Any help would be greatly appreciated. Thank you
3 Replies
TheBoxyBear
TheBoxyBear3y ago
Where do you check the items in the deck? When you leave the deckOfCards method, the arrays you created are out of scope and get deleted.
beefsupreme9731
internal class Card
{
public string[] Deck { get; private set; } = PopulateDeck();

private static string[] PopulateDeck()
{
int deckCounter = 0;
string[] Values =
{
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"10",
"J",
"Q",
"K",
"A"
};

string[] Suits =
{
" of Hearts",
" of Diamonds",
" of Clubs",
" of Spades"
};

string[] returnArray = new string[52];

for (int i = 0; i < Values.Length; i++)
{
for (int j = 0; j < Suits.Length; j++)
{
returnArray[deckCounter] = Values[i] + Suits[j];
deckCounter++;
}
}

return returnArray;
}
}
internal class Card
{
public string[] Deck { get; private set; } = PopulateDeck();

private static string[] PopulateDeck()
{
int deckCounter = 0;
string[] Values =
{
"2",
"3",
"4",
"5",
"6",
"7",
"8",
"9",
"10",
"J",
"Q",
"K",
"A"
};

string[] Suits =
{
" of Hearts",
" of Diamonds",
" of Clubs",
" of Spades"
};

string[] returnArray = new string[52];

for (int i = 0; i < Values.Length; i++)
{
for (int j = 0; j < Suits.Length; j++)
{
returnArray[deckCounter] = Values[i] + Suits[j];
deckCounter++;
}
}

return returnArray;
}
}
Card myCardObject = new();

Console.WriteLine(myCardObject.Deck[2]);
Card myCardObject = new();

Console.WriteLine(myCardObject.Deck[2]);
^ in the Main() program.
Accord
Accord3y ago
Was this issue resolved? If so, run /close - otherwise I will mark this as stale and this post will be archived until there is new activity.

Did you find this page helpful?