The Quiz Application is a web-based platform designed to facilitate quiz creation, registration, login, quiz attempts, and score viewing. This application aims to provide users with an interactive way to engage with quizzes on various topics.
- User registration and login.
- Quiz creation and management by admins.
- User-friendly interface for quiz attempts.
- Score tracking and summary display.
- Secure authentication and data storage.
Before you begin, ensure you have met the following requirements:
- Node.js and npm installed on your machine.
- PostgreSQL Database server set up (local or cloud-based).
- Access to a web browser.
To install the Quiz Application, follow these steps:
- Clone the repository to your local machine:
git clone https://github.com/CoderLovely08/AI-Quiz-App.git
- Navigate to the project directory:
cd AI-Quiz-App
- Install the dependencies:
npm install
To start the application, run the following command:
npm start
Visit http://localhost:3000
in your web browser to access the application.
The Fisher-Yates Shuffle Algorithm, also known as the Knuth Shuffle, is a simple and efficient method for randomly shuffling the elements of an array. It ensures that every permutation of the elements is equally likely, making it suitable for applications where true randomness is required.
The algorithm operates in-place, meaning it modifies the original array. Here are the basic steps:
- Start from the last element in the array.
- Generate a random index between 0 and the current index (inclusive).
- Swap the current element with the element at the randomly generated index.
- Move to the previous element and repeat steps 2 and 3.
This process continues until you reach the first element in the array.
function fisherYatesShuffle(arr) {
for (let i = arr.length - 1; i > 0; i--) {
const j = Math.floor(Math.random() * (i + 1));
[arr[i], arr[j]] = [arr[j], arr[i]];
}
return arr;
}
- Define the
fisherYatesShuffle
function in your code or include it from a library. - Call the function with an array as an argument.
const myArray = [1, 2, 3, 4, 5];
const shuffledArray = fisherYatesShuffle(myArray);
console.log(shuffledArray);
- This algorithm is suitable for scenarios where true randomness is required, such as shuffling a deck of cards or randomizing quiz questions.
- If you need to keep the original array intact, make a copy before applying the shuffle.
Contributions are welcome! Here are some ways you can contribute:
- Fork the repository and make your changes.
- Create a pull request with a detailed description of your changes.
- Wait for your pull request to be reviewed and merged.
This code is provided under the MIT License.