S'inscrire
section-icon

Forums

Parlez de tout ce que vous voulez!

8 sujets de 1 à 8 (sur un total de 8)
  • Auteur
    Messages
  • Membres
      #include <iostream>
      #include <vector>
      #include <cstdlib>
      #include <ctime>
      #include <algorithm>
      
      using namespace std;
      
      const int MAX_PLAYERS = 9;
      const int SMALL_GRID_SIZE = 20;
      const int LARGE_GRID_SIZE = 30;
      const int TOTAL_TILES = 96;
      const int TILES_PER_PLAYER = 10;
      
      struct Player {
          string name;
          char color;
          int startX;
          int startY;
          int tileExchangeCoupons;
          vector<char> tiles;  // Player's set of tiles
      };
      
      // Function to initialize the game grid
      void initializeGrid(vector<vector<char>> &grid, int gridSize) {
          grid.assign(gridSize, vector<char>(gridSize, '.'));  // Initialize grid with '.' representing empty squares
      }
      
      // Function to display the current state of the grid
      void displayGrid(const vector<vector<char>> &grid) {
          for (const auto &row : grid) {
              for (char square : row) {
                  cout << square << " ";
              }
              cout << endl;
          }
      }
      
      // Function to determine the winner based on the size of the covered square
      int determineWinner(const vector<vector<char>> &grid) {
          // Your logic to determine the winner goes here
      }
      
      // Function to generate a random order of tiles
      vector<char> generateRandomTileOrder() {
          vector<char> tilesOrder(TOTAL_TILES);
          for (int i = 0; i < TOTAL_TILES; ++i) {
              tilesOrder[i] = 'A' + i;  // Assuming tile shapes are represented by letters
          }
          random_shuffle(tilesOrder.begin(), tilesOrder.end());
          return tilesOrder;
      }
      
      // Function to distribute tiles to players
      void distributeTiles(vector<Player> &players, const vector<char> &tilesOrder) {
          for (Player &player : players) {
              player.tiles.assign(tilesOrder.begin(), tilesOrder.begin() + TILES_PER_PLAYER);
              tilesOrder.erase(tilesOrder.begin(), tilesOrder.begin() + TILES_PER_PLAYER);
          }
      }
      
      int main() {
          srand(time(0));  // Seed for random number generation
      
          int numPlayers;
          cout << "Enter the number of players (2 to 9): ";
          cin >> numPlayers;
      
          if (numPlayers < 2 || numPlayers > MAX_PLAYERS) {
              cout << "Invalid number of players. Exiting program." << endl;
              return 1;
          }
      
          int gridSize = (numPlayers <= 4) ? SMALL_GRID_SIZE : LARGE_GRID_SIZE;
      
          vector<vector<char>> grid;
          initializeGrid(grid, gridSize);
      
          vector<Player> players;
          players.resize(numPlayers);
      
          // Player setup
          for (int i = 0; i < numPlayers; ++i) {
              cout << "Enter the name for Player " << i + 1 << ": ";
              cin >> players[i].name;
      
              cout << "Choose a color (single character) for " << players[i].name << ": ";
              cin >> players[i].color;
      
              // Initialize starting tile for each player
              players[i].startX = rand() % gridSize;
              players[i].startY = rand() % gridSize;
      
              // Place starting tile on the grid
              grid[players[i].startX][players[i].startY] = players[i].color;
      
              // Initialize tile exchange coupons
              players[i].tileExchangeCoupons = 1;
          }
      
          // Generate random order of tiles
          vector<char> tilesOrder = generateRandomTileOrder();
      
          // Distribute tiles to players
          distributeTiles(players, tilesOrder);
      
          // Display initial grid
          cout << "\nInitial state of the grid:\n";
          displayGrid(grid);
      
          // Your game loop goes here
      
          return 0;
      }
      Admin
      avatar-image

      Shiloh

      @shiloh

      Maître des clés

        Bonjour,
        Je comprends que c’est un jeu de société.
        Malheureusement, tu n’as pas fait de demande, tu as juste mis ton code ! Quelle est ta demande concernant ce code ?

        Membres

          je voudrais savoir pourquoi le iostream ne marche pas quand je lance

          Admin
          avatar-image

          Shiloh

          @shiloh

          Maître des clés

            Plusieurs problème dans ton code :

            1 – il manque les mécaniques de jeu de base et la logique pour déterminer le gagnant.
            2 – Le programme suppose également un certain format pour l’entrée du joueur et ne gère pas de manière robuste les erreurs ou les entrées invalides.
            3 – Pour finir, la façon dont les tuiles sont distribuées doit être révisée, car elle semble actuellement retirer les tuiles déjà distribuées du pool global, ce qui pourrait entraîner des erreurs.

            Je ne suis pas un expert mais essaie ceci :

            #include <iostream>
            #include <vector>
            #include <cstdlib>
            #include <ctime>
            #include <algorithm>
            
            using namespace std;
            
            const int MAX_PLAYERS = 9;
            const int SMALL_GRID_SIZE = 20;
            const int LARGE_GRID_SIZE = 30;
            const int TOTAL_TILES = 96;
            const int TILES_PER_PLAYER = 10;
            
            struct Player {
                string name;
                char color;
                int startX;
                int startY;
                int tileExchangeCoupons;
                vector<char> tiles;  // Ensemble de tuiles du joueur
            };
            
            void initializeGrid(vector<vector<char>> &grid, int gridSize) {
                grid.assign(gridSize, vector<char>(gridSize, '.'));  // Initialisation de la grille avec '.' pour les cases vides
            }
            
            void displayGrid(const vector<vector<char>> &grid) {
                for (const auto &row : grid) {
                    for (char square : row) {
                        cout << square << " ";
                    }
                    cout << endl;
                }
            }
            
            int determineWinner(const vector<vector<char>> &grid, const vector<Player> &players) {
                vector<int> scores(players.size(), 0);
            
                // Calcul des scores pour chaque joueur
                for (int i = 0; i < grid.size(); i++) {
                    for (int j = 0; j < grid[i].size(); j++) {
                        for (int k = 0; k < players.size(); k++) {
                            if (grid[i][j] == players[k].color) {
                                scores[k]++;
                            }
                        }
                    }
                }
            
                // Trouver le joueur avec le score le plus élevé
                int maxScore = 0, winnerIndex = -1;
                for (int i = 0; i < scores.size(); i++) {
                    if (scores[i] > maxScore) {
                        maxScore = scores[i];
                        winnerIndex = i;
                    }
                }
            
                return winnerIndex;
            }
            
            vector<char> generateRandomTileOrder() {
                vector<char> tilesOrder(TOTAL_TILES);
                for (int i = 0; i < TOTAL_TILES; ++i) {
                    tilesOrder[i] = 'A' + i;  // Tuiles représentées par des lettres
                }
                random_shuffle(tilesOrder.begin(), tilesOrder.end());
                return tilesOrder;
            }
            
            void distributeTiles(vector<Player> &players, vector<char> &tilesOrder) {
                for (Player &player : players) {
                    player.tiles.assign(tilesOrder.begin(), tilesOrder.begin() + TILES_PER_PLAYER);
                    tilesOrder.erase(tilesOrder.begin(), tilesOrder.begin() + TILES_PER_PLAYER);
                }
            }
            
            int main() {
                srand(time(0));  // Initialisation du générateur de nombres aléatoires
            
                int numPlayers;
                cout << "Entrez le nombre de joueurs (2 à 9) : ";
                cin >> numPlayers;
            
                if (numPlayers < 2 || numPlayers > MAX_PLAYERS) {
                    cout << "Nombre de joueurs invalide. Fin du programme." << endl;
                    return 1;
                }
            
                int gridSize = (numPlayers <= 4) ? SMALL_GRID_SIZE : LARGE_GRID_SIZE;
            
                vector<vector<char>> grid;
                initializeGrid(grid, gridSize);
            
                vector<Player> players(numPlayers);
            
                // Configuration des joueurs
                for (int i = 0; i < numPlayers; ++i) {
                    cout << "Entrez le nom pour le Joueur " << i + 1 << " : ";
                    cin >> players[i].name;
            
                    cout << "Choisissez une couleur (caractère unique) pour " << players[i].name << " : ";
                    cin >> players[i].color;
            
                    // Initialisation de la position de départ
                    players[i].startX = rand() % gridSize;
                    players[i].startY = rand() % gridSize;
                    grid[players[i].startX][players[i].startY] = players[i].color;
            
                    players[i].tileExchangeCoupons = 1;  // Initialisation des coupons d'échange de tuile
                }
            
                // Génération et distribution des tuiles
                vector<char> tilesOrder = generateRandomTileOrder();
                distributeTiles(players, tilesOrder);
            
                // Affichage de la grille initiale
                cout << "\nÉtat initial de la grille :\n";
                displayGrid(grid);
            
                // Boucle de jeu
                bool gameOver = false;
                int currentPlayerIndex = 0;
            
                while (!gameOver) {
                    // Logique du jeu ici
                    // Exemple : Chaque joueur place une tuile à tour de rôle
                    // ...
            
                    // Vérification de la fin du jeu
                    // gameOver = ...;  // À déterminer selon les règles du jeu
            
                    currentPlayerIndex = (currentPlayerIndex + 1) % numPlayers;
                }
            
                int winnerIndex = determineWinner(grid, players);
                if (winnerIndex != -1) {
                    cout << "Le gagnant est " << players[winnerIndex].name << " !" << endl;
                } else {
                    cout << "Pas de gagnant." << endl;
                }
            
                return 0;
            }
            

            Dans ce code, j’ai ajouté une logique de jeu basique et une fonction determineWinner pour déterminer le gagnant et j’ai corrigé différentes érreurs.

            Membres

              d’accord merci je voudrais savoir sur quelle plateforme vous utiliser code blocks ou vs code

              Admin
              avatar-image

              Shiloh

              @shiloh

              Maître des clés

                Je n’ai pas pu tester le code car je suis sur Sublime Text pour le moment, mais sinon, oui, j’utilise VS Code.

                Ma correction fonctionne-t-elle ?

                Membres

                  négatif je pense que c’est du a code blocks

                  Admin
                  avatar-image

                  Shiloh

                  @shiloh

                  Maître des clés

                    Ok, je te laisse passer sur VS Code tu me diras !

                  2

                  Voix

                  7

                  Réponses

                  8 sujets de 1 à 8 (sur un total de 8)
                  • Vous devez être connecté pour répondre à ce sujet.
                  CERT-FR CERTFR-2026-ALE-005 ALERTE [Màj] Vulnérabilité dans Microsoft Exchange Server (15 mai 2026) 15/05/2026 NVD CVE-1999-0095 HIGH 10 The debug command in Sendmail is enabled, allowing attackers to… 01/10/1988 CISA KEV CVE-2026-48907 EXPLOITÉE Widget Factory Joomla Content Editor Improper Access Control Vulnerability 16/06/2026 CERT-FR CERTFR-2026-ALE-004 ALERTE Vulnérabilité dans F5 BIG-IP Access Policy Manager (31 mars 2026) 31/03/2026 NVD CVE-1999-0082 HIGH 10 CWD ~root command in ftpd allows root access. 11/11/1988 CISA KEV CVE-2026-54420 EXPLOITÉE LiteSpeed cPanel Plugin UNIX Symbolic Link (Symlink) Following Vulnerability 15/06/2026 CERT-FR CERTFR-2026-ALE-003 ALERTE Note d’alerte – Ciblage des messageries instantanées (20 mars 2026) 20/03/2026 NVD CVE-1999-1471 HIGH 7.2 Buffer overflow in passwd in BSD based operating systems 4.3… 01/01/1989 CISA KEV CVE-2026-20262 EXPLOITÉE Cisco Catalyst SD-WAN Manager Directory or Path Traversal Vulnerability 15/06/2026 CERT-FR CERTFR-2026-ALE-002 ALERTE [MàJ] Vulnérabilité dans Cisco Catalyst SD-WAN (25 février 2026) 25/02/2026 NVD CVE-1999-1122 MEDIUM 4.6 Vulnerability in restore in SunOS 4.0.3 and earlier allows local… 26/07/1989 CISA KEV CVE-2026-35273 RANSOMWARE Oracle PeopleSoft Enterprise PeopleTools Missing Authentication for Critical Function Vulnerability 12/06/2026 CERT-FR CERTFR-2026-ALE-001 ALERTE [MàJ] Multiples vulnérabilités dans Ivanti Endpoint Manager Mobile (30 janvier… 30/01/2026 NVD CVE-1999-1467 HIGH 10 Vulnerability in rcp on SunOS 4.0.x allows remote attackers from… 26/10/1989 CISA KEV CVE-2026-10520 EXPLOITÉE Ivanti Sentry OS Command Injection Vulnerability 11/06/2026 CERT-FR CERTFR-2025-ALE-014 ALERTE [MàJ] Vulnérabilité dans React Server Components (05 décembre 2025) 05/12/2025 NVD CVE-1999-1506 HIGH 7.5 Vulnerability in SMI Sendmail 4.0 and earlier, on SunOS up… 29/01/1990 CISA KEV CVE-2026-11645 EXPLOITÉE Google Chromium V8 Out-of-Bounds Read and Write Vulnerability 09/06/2026 CERT-FR CERTFR-2025-ALE-013 ALERTE [MàJ] Multiples vulnérabilités dans Cisco ASA et FTD (25 septembre… 25/09/2025 NVD CVE-1999-0084 HIGH 8.4 Certain NFS servers allow users to use mknod to gain… 01/05/1990 CISA KEV CVE-2026-7473 EXPLOITÉE Arista Extensible Operating System Incomplete Comparison with Missing Factors Vulnerability 09/06/2026 CERT-FR CERTFR-2026-ALE-005 ALERTE [Màj] Vulnérabilité dans Microsoft Exchange Server (15 mai 2026) 15/05/2026 NVD CVE-1999-0095 HIGH 10 The debug command in Sendmail is enabled, allowing attackers to… 01/10/1988 CISA KEV CVE-2026-48907 EXPLOITÉE Widget Factory Joomla Content Editor Improper Access Control Vulnerability 16/06/2026 CERT-FR CERTFR-2026-ALE-004 ALERTE Vulnérabilité dans F5 BIG-IP Access Policy Manager (31 mars 2026) 31/03/2026 NVD CVE-1999-0082 HIGH 10 CWD ~root command in ftpd allows root access. 11/11/1988 CISA KEV CVE-2026-54420 EXPLOITÉE LiteSpeed cPanel Plugin UNIX Symbolic Link (Symlink) Following Vulnerability 15/06/2026 CERT-FR CERTFR-2026-ALE-003 ALERTE Note d’alerte – Ciblage des messageries instantanées (20 mars 2026) 20/03/2026 NVD CVE-1999-1471 HIGH 7.2 Buffer overflow in passwd in BSD based operating systems 4.3… 01/01/1989 CISA KEV CVE-2026-20262 EXPLOITÉE Cisco Catalyst SD-WAN Manager Directory or Path Traversal Vulnerability 15/06/2026 CERT-FR CERTFR-2026-ALE-002 ALERTE [MàJ] Vulnérabilité dans Cisco Catalyst SD-WAN (25 février 2026) 25/02/2026 NVD CVE-1999-1122 MEDIUM 4.6 Vulnerability in restore in SunOS 4.0.3 and earlier allows local… 26/07/1989 CISA KEV CVE-2026-35273 RANSOMWARE Oracle PeopleSoft Enterprise PeopleTools Missing Authentication for Critical Function Vulnerability 12/06/2026 CERT-FR CERTFR-2026-ALE-001 ALERTE [MàJ] Multiples vulnérabilités dans Ivanti Endpoint Manager Mobile (30 janvier… 30/01/2026 NVD CVE-1999-1467 HIGH 10 Vulnerability in rcp on SunOS 4.0.x allows remote attackers from… 26/10/1989 CISA KEV CVE-2026-10520 EXPLOITÉE Ivanti Sentry OS Command Injection Vulnerability 11/06/2026 CERT-FR CERTFR-2025-ALE-014 ALERTE [MàJ] Vulnérabilité dans React Server Components (05 décembre 2025) 05/12/2025 NVD CVE-1999-1506 HIGH 7.5 Vulnerability in SMI Sendmail 4.0 and earlier, on SunOS up… 29/01/1990 CISA KEV CVE-2026-11645 EXPLOITÉE Google Chromium V8 Out-of-Bounds Read and Write Vulnerability 09/06/2026 CERT-FR CERTFR-2025-ALE-013 ALERTE [MàJ] Multiples vulnérabilités dans Cisco ASA et FTD (25 septembre… 25/09/2025 NVD CVE-1999-0084 HIGH 8.4 Certain NFS servers allow users to use mknod to gain… 01/05/1990 CISA KEV CVE-2026-7473 EXPLOITÉE Arista Extensible Operating System Incomplete Comparison with Missing Factors Vulnerability 09/06/2026