From 33613a85afc4b1481367fbe92a17ee59c240250b Mon Sep 17 00:00:00 2001 From: Sven Eisenhauer Date: Fri, 10 Nov 2023 15:11:48 +0100 Subject: add new repo --- Bachelor/Prog1/examples/ch05/Fig05_24.cpp | 103 ++++++++++++++++++++++++++++++ 1 file changed, 103 insertions(+) create mode 100644 Bachelor/Prog1/examples/ch05/Fig05_24.cpp (limited to 'Bachelor/Prog1/examples/ch05/Fig05_24.cpp') diff --git a/Bachelor/Prog1/examples/ch05/Fig05_24.cpp b/Bachelor/Prog1/examples/ch05/Fig05_24.cpp new file mode 100644 index 0000000..746fd13 --- /dev/null +++ b/Bachelor/Prog1/examples/ch05/Fig05_24.cpp @@ -0,0 +1,103 @@ +// Fig. 5.24: fig05_24.cpp +// Card shuffling dealing program. +#include + +using std::cout; +using std::left; +using std::right; + +#include + +using std::setw; + +#include // prototypes for rand and srand +#include // prototype for time + +// prototypes +void shuffle( int [][ 13 ] ); +void deal( const int [][ 13 ], const char *[], const char *[] ); + +int main() +{ + // initialize suit array + const char *suit[ 4 ] = + { "Hearts", "Diamonds", "Clubs", "Spades" }; + + // initialize face array + const char *face[ 13 ] = + { "Ace", "Deuce", "Three", "Four", + "Five", "Six", "Seven", "Eight", + "Nine", "Ten", "Jack", "Queen", "King" }; + + // initialize deck array + int deck[ 4 ][ 13 ] = { 0 }; + + srand( time( 0 ) ); // seed random number generator + + shuffle( deck ); + deal( deck, face, suit ); + + return 0; // indicates successful termination + +} // end main + +// shuffle cards in deck +void shuffle( int wDeck[][ 13 ] ) +{ + int row; + int column; + + // for each of the 52 cards, choose slot of deck randomly + for ( int card = 1; card <= 52; card++ ) { + + // choose new random location until unoccupied slot found + do { + row = rand() % 4; + column = rand() % 13; + } while( wDeck[ row ][ column ] != 0 ); // end do/while + + // place card number in chosen slot of deck + wDeck[ row ][ column ] = card; + + } // end for + +} // end function shuffle + +// deal cards in deck +void deal( const int wDeck[][ 13 ], const char *wFace[], + const char *wSuit[] ) +{ + // for each of the 52 cards + for ( int card = 1; card <= 52; card++ ) + + // loop through rows of wDeck + for ( int row = 0; row <= 3; row++ ) + + // loop through columns of wDeck for current row + for ( int column = 0; column <= 12; column++ ) + + // if slot contains current card, display card + if ( wDeck[ row ][ column ] == card ) { + cout << setw( 5 ) << right << wFace[ column ] + << " of " << setw( 8 ) << left + << wSuit[ row ] + << ( card % 2 == 0 ? '\n' : '\t' ); + + } // end if + +} // end function deal + +/************************************************************************** + * (C) Copyright 1992-2003 by Deitel & Associates, Inc. and Prentice * + * Hall. All Rights Reserved. * + * * + * DISCLAIMER: The authors and publisher of this book have used their * + * best efforts in preparing the book. These efforts include the * + * development, research, and testing of the theories and programs * + * to determine their effectiveness. The authors and publisher make * + * no warranty of any kind, expressed or implied, with regard to these * + * programs or to the documentation contained in these books. The authors * + * and publisher shall not be liable in any event for incidental or * + * consequential damages in connection with, or arising out of, the * + * furnishing, performance, or use of these programs. * + *************************************************************************/ -- cgit v1.2.3