diff --git a/README.md b/README.md index 1d3768a80..7e0c276cc 100644 --- a/README.md +++ b/README.md @@ -107,7 +107,6 @@ Happy coding! ## Thanks to Our Contributors 🌟 - <a href = "https://github.com/subhadipbhowmik/30-Days-Of-CPP/graphs/contributors"> <img src = "https://contrib.rocks/image?repo=subhadipbhowmik/30-Days-Of-CPP"/> </a> diff --git a/SECURITY.md b/SECURITY.md deleted file mode 100644 index 034e84803..000000000 --- a/SECURITY.md +++ /dev/null @@ -1,21 +0,0 @@ -# Security Policy - -## Supported Versions - -Use this section to tell people about which versions of your project are -currently being supported with security updates. - -| Version | Supported | -| ------- | ------------------ | -| 5.1.x | :white_check_mark: | -| 5.0.x | :x: | -| 4.0.x | :white_check_mark: | -| < 4.0 | :x: | - -## Reporting a Vulnerability - -Use this section to tell people how to report a vulnerability. - -Tell them where to go, how often they can expect to get an update on a -reported vulnerability, what to expect if the vulnerability is accepted or -declined, etc. diff --git a/backend/.gitignore b/backend/.gitignore deleted file mode 100644 index 0c4f703e5..000000000 --- a/backend/.gitignore +++ /dev/null @@ -1,28 +0,0 @@ -# Node modules -node_modules/ - -# Environment variables -.env - -# IDE/Editor specific files -.vscode/ -.idea/ - -# Dependency directories (remove if not using Yarn) -/yarn-error.log -/.pnp -.pnp.js - -# macOS specific files -.DS_Store - -# Windows thumbnail cache files -Thumbs.db - -# Logs -logs/ -*.log - -# Build directories (remove if not using any build tools) -/build/ -/dist/ diff --git a/backend/config/config.js b/backend/config/config.js deleted file mode 100644 index 8c61e8c3e..000000000 --- a/backend/config/config.js +++ /dev/null @@ -1,6 +0,0 @@ -// config/config.js -module.exports = { - JWT_SECRET: 'your_jwt_secret', // Replace with your own secret - mongoURI: 'ADD_MONGO_DB_URI' // Replace with your MongoDB URI -}; -//must be replaced with .env file in futher commets \ No newline at end of file diff --git a/backend/controllers/authController.js b/backend/controllers/authController.js deleted file mode 100644 index df1b0be34..000000000 --- a/backend/controllers/authController.js +++ /dev/null @@ -1,69 +0,0 @@ -// controllers/authController.js -const bcrypt = require('bcryptjs'); -const jwt = require('jsonwebtoken'); -const User = require('../models/user'); -const config = require('../config/config'); - -exports.signup = async (req, res) => { - const { username, email, password } = req.body; - - try { - // Check if user already exists - const existingUser = await User.findOne({ email }); - const existingUsername = await User.findOne({ username }); - if (existingUser) { - return res.status(400).json({ message: 'User already exists' }); - } - if (existingUsername) { - return res.status(400).json({ message: 'Username already exists' }); - } - - // Hash the password - const hashedPassword = await bcrypt.hash(password, 10); - - // Create new user - const newUser = new User({ - username, - email, - password: hashedPassword - }); - - await newUser.save(); - - // Generate JWT token - const token = jwt.sign({ userId: newUser._id }, config.JWT_SECRET, { expiresIn: '1h' }); - - // Respond with token - res.status(201).json({ token }); - } catch (error) { - console.error('Signup error:', error); - res.status(500).json({ message: 'Server error' }); - } -}; - -exports.login = async (req, res) => { - const { email, password } = req.body; - - try { - // Check if user exists - const user = await User.findOne({ email }); - if (!user) { - return res.status(400).json({ message: 'Invalid email or password' }); - } - - // Check password - const isMatch = await bcrypt.compare(password, user.password); - if (!isMatch) { - return res.status(400).json({ message: 'Invalid email or password' }); - } - - // Generate JWT token - const token = jwt.sign({ userId: user._id }, config.JWT_SECRET, { expiresIn: '1h' }); - - // Respond with token - res.status(200).json({ token }); - } catch (error) { - console.error('Login error:', error); - res.status(500).json({ message: 'Server error' }); - } -}; diff --git a/backend/controllers/errorHandler.js b/backend/controllers/errorHandler.js deleted file mode 100644 index 56f46ac13..000000000 --- a/backend/controllers/errorHandler.js +++ /dev/null @@ -1 +0,0 @@ -// Centralized error handling middleware \ No newline at end of file diff --git a/backend/index.js b/backend/index.js deleted file mode 100644 index c6958c2fc..000000000 --- a/backend/index.js +++ /dev/null @@ -1,35 +0,0 @@ -// index.js -const express = require('express'); -const mongoose = require('mongoose'); -const bodyParser = require('body-parser'); -const cors = require('cors'); -const config = require('./config/config'); -const router = require('./routers/router'); - -const app = express(); -const PORT = process.env.PORT || 5000; - -// Middleware -app.use(bodyParser.json()); -app.use(cors()); - -// MongoDB connection -mongoose.connect(config.mongoURI, { - useNewUrlParser: true, - useUnifiedTopology: true -}) -.then(() => console.log('MongoDB connected')) -.catch(err => console.error('MongoDB connection error:', err)); - -// Routes -app.use('/api', router); - -// Error handling middleware -app.use((err, req, res, next) => { - console.error('Error:', err.stack); - res.status(500).json({ message: 'Server error' }); -}); - -app.listen(PORT, () => { - console.log(`Server running on port ${PORT}`); -}); diff --git a/backend/middleware/authMiddleware.js b/backend/middleware/authMiddleware.js deleted file mode 100644 index 170f474fd..000000000 --- a/backend/middleware/authMiddleware.js +++ /dev/null @@ -1,24 +0,0 @@ -// middleware/authMiddleware.js -const jwt = require('jsonwebtoken'); -const config = require('../config/config'); - -module.exports = (req, res, next) => { - // Get token from header - const token = req.header('Authorization'); - - // Check if not token - if (!token) { - return res.status(401).json({ message: 'Authorization denied' }); - } - - try { - // Verify token - const decoded = jwt.verify(token, config.JWT_SECRET); - - // Add user from payload - req.user = decoded; - next(); - } catch (error) { - res.status(401).json({ message: 'Token is not valid' }); - } -}; diff --git a/backend/middleware/validationMiddleware.js b/backend/middleware/validationMiddleware.js deleted file mode 100644 index 65e2f4bed..000000000 --- a/backend/middleware/validationMiddleware.js +++ /dev/null @@ -1,18 +0,0 @@ -// middleware/validationMiddleware.js -// Example validation middleware using Joi -const Joi = require('joi'); - -exports.validateSignup = (req, res, next) => { - const schema = Joi.object({ - username: Joi.string().alphanum().min(3).max(30).required(), - email: Joi.string().email().required(), - password: Joi.string().min(6).required() - }); - - const { error } = schema.validate(req.body); - if (error) { - return res.status(400).json({ message: error.details[0].message }); - } - - next(); -}; diff --git a/backend/models/user.js b/backend/models/user.js deleted file mode 100644 index f2cf7fa0b..000000000 --- a/backend/models/user.js +++ /dev/null @@ -1,10 +0,0 @@ -// models/user.js -const mongoose = require('mongoose'); - -const userSchema = new mongoose.Schema({ - username: { type: String, required: true, unique: true }, - email: { type: String, required: true, unique: true }, - password: { type: String, required: true } -}); - -module.exports = mongoose.model('User', userSchema); diff --git a/backend/package-lock.json b/backend/package-lock.json deleted file mode 100644 index b1147524c..000000000 --- a/backend/package-lock.json +++ /dev/null @@ -1,1345 +0,0 @@ -{ - "name": "backend", - "version": "1.0.0", - "lockfileVersion": 3, - "requires": true, - "packages": { - "": { - "name": "backend", - "version": "1.0.0", - "license": "ISC", - "dependencies": { - "bcryptjs": "^2.4.3", - "body-parser": "^1.20.2", - "cors": "^2.8.5", - "express": "^4.19.2", - "jsonwebtoken": "^9.0.2", - "mongoose": "^8.4.1", - "nodemon": "^3.1.3" - } - }, - "node_modules/@mongodb-js/saslprep": { - "version": "1.1.7", - "resolved": "https://registry.npmjs.org/@mongodb-js/saslprep/-/saslprep-1.1.7.tgz", - "integrity": "sha512-dCHW/oEX0KJ4NjDULBo3JiOaK5+6axtpBbS+ao2ZInoAL9/YRQLhXzSNAFz7hP4nzLkIqsfYAK/PDE3+XHny0Q==", - "dependencies": { - "sparse-bitfield": "^3.0.3" - } - }, - "node_modules/@types/webidl-conversions": { - "version": "7.0.3", - "resolved": "https://registry.npmjs.org/@types/webidl-conversions/-/webidl-conversions-7.0.3.tgz", - "integrity": "sha512-CiJJvcRtIgzadHCYXw7dqEnMNRjhGZlYK05Mj9OyktqV8uVT8fD2BFOB7S1uwBE3Kj2Z+4UyPmFw/Ixgw/LAlA==" - }, - "node_modules/@types/whatwg-url": { - "version": "11.0.5", - "resolved": "https://registry.npmjs.org/@types/whatwg-url/-/whatwg-url-11.0.5.tgz", - "integrity": "sha512-coYR071JRaHa+xoEvvYqvnIHaVqaYrLPbsufM9BF63HkwI5Lgmy2QR8Q5K/lYDYo5AK82wOvSOS0UsLTpTG7uQ==", - "dependencies": { - "@types/webidl-conversions": "*" - } - }, - "node_modules/accepts": { - "version": "1.3.8", - "resolved": "https://registry.npmjs.org/accepts/-/accepts-1.3.8.tgz", - "integrity": "sha512-PYAthTa2m2VKxuvSD3DPC/Gy+U+sOA1LAuT8mkmRuvw+NACSaeXEQ+NHcVF7rONl6qcaxV3Uuemwawk+7+SJLw==", - "dependencies": { - "mime-types": "~2.1.34", - "negotiator": "0.6.3" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/anymatch": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/anymatch/-/anymatch-3.1.3.tgz", - "integrity": "sha512-KMReFUr0B4t+D+OBkjR3KYqvocp2XaSzO55UcB6mgQMd3KbcE+mWTyvVV7D/zsdEbNnV6acZUutkiHQXvTr1Rw==", - "dependencies": { - "normalize-path": "^3.0.0", - "picomatch": "^2.0.4" - }, - "engines": { - "node": ">= 8" - } - }, - "node_modules/array-flatten": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/array-flatten/-/array-flatten-1.1.1.tgz", - "integrity": "sha512-PCVAQswWemu6UdxsDFFX/+gVeYqKAod3D3UVm91jHwynguOwAvYPhx8nNlM++NqRcK6CxxpUafjmhIdKiHibqg==" - }, - "node_modules/balanced-match": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/balanced-match/-/balanced-match-1.0.2.tgz", - "integrity": "sha512-3oSeUO0TMV67hN1AmbXsK4yaqU7tjiHlbxRDZOpH0KW9+CeX4bRAaX0Anxt0tx2MrpRpWwQaPwIlISEJhYU5Pw==" - }, - "node_modules/bcryptjs": { - "version": "2.4.3", - "resolved": "https://registry.npmjs.org/bcryptjs/-/bcryptjs-2.4.3.tgz", - "integrity": "sha512-V/Hy/X9Vt7f3BbPJEi8BdVFMByHi+jNXrYkW3huaybV/kQ0KJg0Y6PkEMbn+zeT+i+SiKZ/HMqJGIIt4LZDqNQ==" - }, - "node_modules/binary-extensions": { - "version": "2.3.0", - "resolved": "https://registry.npmjs.org/binary-extensions/-/binary-extensions-2.3.0.tgz", - "integrity": "sha512-Ceh+7ox5qe7LJuLHoY0feh3pHuUDHAcRUeyL2VYghZwfpkNIy/+8Ocg0a3UuSoYzavmylwuLWQOf3hl0jjMMIw==", - "engines": { - "node": ">=8" - }, - "funding": { - "url": "https://github.com/sponsors/sindresorhus" - } - }, - "node_modules/body-parser": { - "version": "1.20.2", - "resolved": "https://registry.npmjs.org/body-parser/-/body-parser-1.20.2.tgz", - "integrity": "sha512-ml9pReCu3M61kGlqoTm2umSXTlRTuGTx0bfYj+uIUKKYycG5NtSbeetV3faSU6R7ajOPw0g/J1PvK4qNy7s5bA==", - "dependencies": { - "bytes": "3.1.2", - "content-type": "~1.0.5", - "debug": "2.6.9", - "depd": "2.0.0", - "destroy": "1.2.0", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "on-finished": "2.4.1", - "qs": "6.11.0", - "raw-body": "2.5.2", - "type-is": "~1.6.18", - "unpipe": "1.0.0" - }, - "engines": { - "node": ">= 0.8", - "npm": "1.2.8000 || >= 1.4.16" - } - }, - "node_modules/brace-expansion": { - "version": "1.1.11", - "resolved": "https://registry.npmjs.org/brace-expansion/-/brace-expansion-1.1.11.tgz", - "integrity": "sha512-iCuPHDFgrHX7H2vEI/5xpz07zSHB00TpugqhmYtVmMO6518mCuRMoOYFldEBl0g187ufozdaHgWKcYFb61qGiA==", - "dependencies": { - "balanced-match": "^1.0.0", - "concat-map": "0.0.1" - } - }, - "node_modules/braces": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/braces/-/braces-3.0.3.tgz", - "integrity": "sha512-yQbXgO/OSZVD2IsiLlro+7Hf6Q18EJrKSEsdoMzKePKXct3gvD8oLcOQdIzGupr5Fj+EDe8gO/lxc1BzfMpxvA==", - "dependencies": { - "fill-range": "^7.1.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/bson": { - "version": "6.7.0", - "resolved": "https://registry.npmjs.org/bson/-/bson-6.7.0.tgz", - "integrity": "sha512-w2IquM5mYzYZv6rs3uN2DZTOBe2a0zXLj53TGDqwF4l6Sz/XsISrisXOJihArF9+BZ6Cq/GjVht7Sjfmri7ytQ==", - "engines": { - "node": ">=16.20.1" - } - }, - "node_modules/buffer-equal-constant-time": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/buffer-equal-constant-time/-/buffer-equal-constant-time-1.0.1.tgz", - "integrity": "sha512-zRpUiDwd/xk6ADqPMATG8vc9VPrkck7T07OIx0gnjmJAnHnTVXNQG3vfvWNuiZIkwu9KrKdA1iJKfsfTVxE6NA==" - }, - "node_modules/bytes": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/bytes/-/bytes-3.1.2.tgz", - "integrity": "sha512-/Nf7TyzTx6S3yRJObOAV7956r8cr2+Oj8AC5dt8wSP3BQAoeX58NoHyCU8P8zGkNXStjTSi6fzO6F0pBdcYbEg==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/call-bind": { - "version": "1.0.7", - "resolved": "https://registry.npmjs.org/call-bind/-/call-bind-1.0.7.tgz", - "integrity": "sha512-GHTSNSYICQ7scH7sZ+M2rFopRoLh8t2bLSW6BbgrtLsahOIB5iyAVJf9GjWK3cYTDaMj4XdBpM1cA6pIS0Kv2w==", - "dependencies": { - "es-define-property": "^1.0.0", - "es-errors": "^1.3.0", - "function-bind": "^1.1.2", - "get-intrinsic": "^1.2.4", - "set-function-length": "^1.2.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/chokidar": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/chokidar/-/chokidar-3.6.0.tgz", - "integrity": "sha512-7VT13fmjotKpGipCW9JEQAusEPE+Ei8nl6/g4FBAmIm0GOOLMua9NDDo/DWp0ZAxCr3cPq5ZpBqmPAQgDda2Pw==", - "dependencies": { - "anymatch": "~3.1.2", - "braces": "~3.0.2", - "glob-parent": "~5.1.2", - "is-binary-path": "~2.1.0", - "is-glob": "~4.0.1", - "normalize-path": "~3.0.0", - "readdirp": "~3.6.0" - }, - "engines": { - "node": ">= 8.10.0" - }, - "funding": { - "url": "https://paulmillr.com/funding/" - }, - "optionalDependencies": { - "fsevents": "~2.3.2" - } - }, - "node_modules/concat-map": { - "version": "0.0.1", - "resolved": "https://registry.npmjs.org/concat-map/-/concat-map-0.0.1.tgz", - "integrity": "sha512-/Srv4dswyQNBfohGpz9o6Yb3Gz3SrUDqBH5rTuhGR7ahtlbYKnVxw2bCFMRljaA7EXHaXZ8wsHdodFvbkhKmqg==" - }, - "node_modules/content-disposition": { - "version": "0.5.4", - "resolved": "https://registry.npmjs.org/content-disposition/-/content-disposition-0.5.4.tgz", - "integrity": "sha512-FveZTNuGw04cxlAiWbzi6zTAL/lhehaWbTtgluJh4/E95DqMwTmha3KZN1aAWA8cFIhHzMZUvLevkw5Rqk+tSQ==", - "dependencies": { - "safe-buffer": "5.2.1" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/content-type": { - "version": "1.0.5", - "resolved": "https://registry.npmjs.org/content-type/-/content-type-1.0.5.tgz", - "integrity": "sha512-nTjqfcBFEipKdXCv4YDQWCfmcLZKm81ldF0pAopTvyrFGVbcR6P/VAAd5G7N+0tTr8QqiU0tFadD6FK4NtJwOA==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/cookie": { - "version": "0.6.0", - "resolved": "https://registry.npmjs.org/cookie/-/cookie-0.6.0.tgz", - "integrity": "sha512-U71cyTamuh1CRNCfpGY6to28lxvNwPG4Guz/EVjgf3Jmzv0vlDp1atT9eS5dDjMYHucpHbWns6Lwf3BKz6svdw==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/cookie-signature": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/cookie-signature/-/cookie-signature-1.0.6.tgz", - "integrity": "sha512-QADzlaHc8icV8I7vbaJXJwod9HWYp8uCqf1xa4OfNu1T7JVxQIrUgOWtHdNDtPiywmFbiS12VjotIXLrKM3orQ==" - }, - "node_modules/cors": { - "version": "2.8.5", - "resolved": "https://registry.npmjs.org/cors/-/cors-2.8.5.tgz", - "integrity": "sha512-KIHbLJqu73RGr/hnbrO9uBeixNGuvSQjul/jdFvS/KFSIH1hWVd1ng7zOHx+YrEfInLG7q4n6GHQ9cDtxv/P6g==", - "dependencies": { - "object-assign": "^4", - "vary": "^1" - }, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/debug": { - "version": "2.6.9", - "resolved": "https://registry.npmjs.org/debug/-/debug-2.6.9.tgz", - "integrity": "sha512-bC7ElrdJaJnPbAP+1EotYvqZsb3ecl5wi6Bfi6BJTUcNowp6cvspg0jXznRTKDjm/E7AdgFBVeAPVMNcKGsHMA==", - "dependencies": { - "ms": "2.0.0" - } - }, - "node_modules/define-data-property": { - "version": "1.1.4", - "resolved": "https://registry.npmjs.org/define-data-property/-/define-data-property-1.1.4.tgz", - "integrity": "sha512-rBMvIzlpA8v6E+SJZoo++HAYqsLrkg7MSfIinMPFhmkorw7X+dOXVJQs+QT69zGkzMyfDnIMN2Wid1+NbL3T+A==", - "dependencies": { - "es-define-property": "^1.0.0", - "es-errors": "^1.3.0", - "gopd": "^1.0.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/depd": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/depd/-/depd-2.0.0.tgz", - "integrity": "sha512-g7nH6P6dyDioJogAAGprGpCtVImJhpPk/roCzdb3fIh61/s/nPsfR6onyMwkCAR/OlC3yBC0lESvUoQEAssIrw==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/destroy": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/destroy/-/destroy-1.2.0.tgz", - "integrity": "sha512-2sJGJTaXIIaR1w4iJSNoN0hnMY7Gpc/n8D4qSCJw8QqFWXf7cuAgnEHxBpweaVcPevC2l3KpjYCx3NypQQgaJg==", - "engines": { - "node": ">= 0.8", - "npm": "1.2.8000 || >= 1.4.16" - } - }, - "node_modules/ecdsa-sig-formatter": { - "version": "1.0.11", - "resolved": "https://registry.npmjs.org/ecdsa-sig-formatter/-/ecdsa-sig-formatter-1.0.11.tgz", - "integrity": "sha512-nagl3RYrbNv6kQkeJIpt6NJZy8twLB/2vtz6yN9Z4vRKHN4/QZJIEbqohALSgwKdnksuY3k5Addp5lg8sVoVcQ==", - "dependencies": { - "safe-buffer": "^5.0.1" - } - }, - "node_modules/ee-first": { - "version": "1.1.1", - "resolved": "https://registry.npmjs.org/ee-first/-/ee-first-1.1.1.tgz", - "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" - }, - "node_modules/encodeurl": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/encodeurl/-/encodeurl-1.0.2.tgz", - "integrity": "sha512-TPJXq8JqFaVYm2CWmPvnP2Iyo4ZSM7/QKcSmuMLDObfpH5fi7RUGmd/rTDf+rut/saiDiQEeVTNgAmJEdAOx0w==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/es-define-property": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/es-define-property/-/es-define-property-1.0.0.tgz", - "integrity": "sha512-jxayLKShrEqqzJ0eumQbVhTYQM27CfT1T35+gCgDFoL82JLsXqTJ76zv6A0YLOgEnLUMvLzsDsGIrl8NFpT2gQ==", - "dependencies": { - "get-intrinsic": "^1.2.4" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/es-errors": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/es-errors/-/es-errors-1.3.0.tgz", - "integrity": "sha512-Zf5H2Kxt2xjTvbJvP2ZWLEICxA6j+hAmMzIlypy4xcBg1vKVnx89Wy0GbS+kf5cwCVFFzdCFh2XSCFNULS6csw==", - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/escape-html": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/escape-html/-/escape-html-1.0.3.tgz", - "integrity": "sha512-NiSupZ4OeuGwr68lGIeym/ksIZMJodUGOSCZ/FSnTxcrekbvqrgdUxlJOMpijaKZVjAJrWrGs/6Jy8OMuyj9ow==" - }, - "node_modules/etag": { - "version": "1.8.1", - "resolved": "https://registry.npmjs.org/etag/-/etag-1.8.1.tgz", - "integrity": "sha512-aIL5Fx7mawVa300al2BnEE4iNvo1qETxLrPI/o05L7z6go7fCw1J6EQmbK4FmJ2AS7kgVF/KEZWufBfdClMcPg==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/express": { - "version": "4.19.2", - "resolved": "https://registry.npmjs.org/express/-/express-4.19.2.tgz", - "integrity": "sha512-5T6nhjsT+EOMzuck8JjBHARTHfMht0POzlA60WV2pMD3gyXw2LZnZ+ueGdNxG+0calOJcWKbpFcuzLZ91YWq9Q==", - "dependencies": { - "accepts": "~1.3.8", - "array-flatten": "1.1.1", - "body-parser": "1.20.2", - "content-disposition": "0.5.4", - "content-type": "~1.0.4", - "cookie": "0.6.0", - "cookie-signature": "1.0.6", - "debug": "2.6.9", - "depd": "2.0.0", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "etag": "~1.8.1", - "finalhandler": "1.2.0", - "fresh": "0.5.2", - "http-errors": "2.0.0", - "merge-descriptors": "1.0.1", - "methods": "~1.1.2", - "on-finished": "2.4.1", - "parseurl": "~1.3.3", - "path-to-regexp": "0.1.7", - "proxy-addr": "~2.0.7", - "qs": "6.11.0", - "range-parser": "~1.2.1", - "safe-buffer": "5.2.1", - "send": "0.18.0", - "serve-static": "1.15.0", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "type-is": "~1.6.18", - "utils-merge": "1.0.1", - "vary": "~1.1.2" - }, - "engines": { - "node": ">= 0.10.0" - } - }, - "node_modules/fill-range": { - "version": "7.1.1", - "resolved": "https://registry.npmjs.org/fill-range/-/fill-range-7.1.1.tgz", - "integrity": "sha512-YsGpe3WHLK8ZYi4tWDg2Jy3ebRz2rXowDxnld4bkQB00cc/1Zw9AWnC0i9ztDJitivtQvaI9KaLyKrc+hBW0yg==", - "dependencies": { - "to-regex-range": "^5.0.1" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/finalhandler": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/finalhandler/-/finalhandler-1.2.0.tgz", - "integrity": "sha512-5uXcUVftlQMFnWC9qu/svkWv3GTd2PfUhK/3PLkYNAe7FbqJMt3515HaxE6eRL74GdsriiwujiawdaB1BpEISg==", - "dependencies": { - "debug": "2.6.9", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "on-finished": "2.4.1", - "parseurl": "~1.3.3", - "statuses": "2.0.1", - "unpipe": "~1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/forwarded": { - "version": "0.2.0", - "resolved": "https://registry.npmjs.org/forwarded/-/forwarded-0.2.0.tgz", - "integrity": "sha512-buRG0fpBtRHSTCOASe6hD258tEubFoRLb4ZNA6NxMVHNw2gOcwHo9wyablzMzOA5z9xA9L1KNjk/Nt6MT9aYow==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/fresh": { - "version": "0.5.2", - "resolved": "https://registry.npmjs.org/fresh/-/fresh-0.5.2.tgz", - "integrity": "sha512-zJ2mQYM18rEFOudeV4GShTGIQ7RbzA7ozbU9I/XBpm7kqgMywgmylMwXHxZJmkVoYkna9d2pVXVXPdYTP9ej8Q==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/fsevents": { - "version": "2.3.3", - "resolved": "https://registry.npmjs.org/fsevents/-/fsevents-2.3.3.tgz", - "integrity": "sha512-5xoDfX+fL7faATnagmWPpbFtwh/R77WmMMqqHGS65C3vvB0YHrgF+B1YmZ3441tMj5n63k0212XNoJwzlhffQw==", - "hasInstallScript": true, - "optional": true, - "os": [ - "darwin" - ], - "engines": { - "node": "^8.16.0 || ^10.6.0 || >=11.0.0" - } - }, - "node_modules/function-bind": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/function-bind/-/function-bind-1.1.2.tgz", - "integrity": "sha512-7XHNxH7qX9xG5mIwxkhumTox/MIRNcOgDrxWsMt2pAr23WHp6MrRlN7FBSFpCpr+oVO0F744iUgR82nJMfG2SA==", - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/get-intrinsic": { - "version": "1.2.4", - "resolved": "https://registry.npmjs.org/get-intrinsic/-/get-intrinsic-1.2.4.tgz", - "integrity": "sha512-5uYhsJH8VJBTv7oslg4BznJYhDoRI6waYCxMmCdnTrcCrHA/fCFKoTFz2JKKE0HdDFUF7/oQuhzumXJK7paBRQ==", - "dependencies": { - "es-errors": "^1.3.0", - "function-bind": "^1.1.2", - "has-proto": "^1.0.1", - "has-symbols": "^1.0.3", - "hasown": "^2.0.0" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/glob-parent": { - "version": "5.1.2", - "resolved": "https://registry.npmjs.org/glob-parent/-/glob-parent-5.1.2.tgz", - "integrity": "sha512-AOIgSQCepiJYwP3ARnGx+5VnTu2HBYdzbGP45eLw1vr3zB3vZLeyed1sC9hnbcOc9/SrMyM5RPQrkGz4aS9Zow==", - "dependencies": { - "is-glob": "^4.0.1" - }, - "engines": { - "node": ">= 6" - } - }, - "node_modules/gopd": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/gopd/-/gopd-1.0.1.tgz", - "integrity": "sha512-d65bNlIadxvpb/A2abVdlqKqV563juRnZ1Wtk6s1sIR8uNsXR70xqIzVqxVf1eTqDunwT2MkczEeaezCKTZhwA==", - "dependencies": { - "get-intrinsic": "^1.1.3" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-flag": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/has-flag/-/has-flag-3.0.0.tgz", - "integrity": "sha512-sKJf1+ceQBr4SMkvQnBDNDtf4TXpVhVGateu0t918bl30FnbE2m4vNLX+VWe/dpjlb+HugGYzW7uQXH98HPEYw==", - "engines": { - "node": ">=4" - } - }, - "node_modules/has-property-descriptors": { - "version": "1.0.2", - "resolved": "https://registry.npmjs.org/has-property-descriptors/-/has-property-descriptors-1.0.2.tgz", - "integrity": "sha512-55JNKuIW+vq4Ke1BjOTjM2YctQIvCT7GFzHwmfZPGo5wnrgkid0YQtnAleFSqumZm4az3n2BS+erby5ipJdgrg==", - "dependencies": { - "es-define-property": "^1.0.0" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-proto": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has-proto/-/has-proto-1.0.3.tgz", - "integrity": "sha512-SJ1amZAJUiZS+PhsVLf5tGydlaVB8EdFpaSO4gmiUKUOxk8qzn5AIy4ZeJUmh22znIdk/uMAUT2pl3FxzVUH+Q==", - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/has-symbols": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/has-symbols/-/has-symbols-1.0.3.tgz", - "integrity": "sha512-l3LCuF6MgDNwTDKkdYGEihYjt5pRPbEg46rtlmnSPlUbgmB8LOIrKJbYYFBSbnPaJexMKtiPO8hmeRjRz2Td+A==", - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/hasown": { - "version": "2.0.2", - "resolved": "https://registry.npmjs.org/hasown/-/hasown-2.0.2.tgz", - "integrity": "sha512-0hJU9SCPvmMzIBdZFqNPXWa6dqh7WdH0cII9y+CyS8rG3nL48Bclra9HmKhVVUHyPWNH5Y7xDwAB7bfgSjkUMQ==", - "dependencies": { - "function-bind": "^1.1.2" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/http-errors": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/http-errors/-/http-errors-2.0.0.tgz", - "integrity": "sha512-FtwrG/euBzaEjYeRqOgly7G0qviiXoJWnvEH2Z1plBdXgbyjv34pHTSb9zoeHMyDy33+DWy5Wt9Wo+TURtOYSQ==", - "dependencies": { - "depd": "2.0.0", - "inherits": "2.0.4", - "setprototypeof": "1.2.0", - "statuses": "2.0.1", - "toidentifier": "1.0.1" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/iconv-lite": { - "version": "0.4.24", - "resolved": "https://registry.npmjs.org/iconv-lite/-/iconv-lite-0.4.24.tgz", - "integrity": "sha512-v3MXnZAcvnywkTUEZomIActle7RXXeedOR31wwl7VlyoXO4Qi9arvSenNQWne1TcRwhCL1HwLI21bEqdpj8/rA==", - "dependencies": { - "safer-buffer": ">= 2.1.2 < 3" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/ignore-by-default": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/ignore-by-default/-/ignore-by-default-1.0.1.tgz", - "integrity": "sha512-Ius2VYcGNk7T90CppJqcIkS5ooHUZyIQK+ClZfMfMNFEF9VSE73Fq+906u/CWu92x4gzZMWOwfFYckPObzdEbA==" - }, - "node_modules/inherits": { - "version": "2.0.4", - "resolved": "https://registry.npmjs.org/inherits/-/inherits-2.0.4.tgz", - "integrity": "sha512-k/vGaX4/Yla3WzyMCvTQOXYeIHvqOKtnqBduzTHpzpQZzAskKMhZ2K+EnBiSM9zGSoIFeMpXKxa4dYeZIQqewQ==" - }, - "node_modules/ipaddr.js": { - "version": "1.9.1", - "resolved": "https://registry.npmjs.org/ipaddr.js/-/ipaddr.js-1.9.1.tgz", - "integrity": "sha512-0KI/607xoxSToH7GjN1FfSbLoU0+btTicjsQSWQlh/hZykN8KpmMf7uYwPW3R+akZ6R/w18ZlXSHBYXiYUPO3g==", - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/is-binary-path": { - "version": "2.1.0", - "resolved": "https://registry.npmjs.org/is-binary-path/-/is-binary-path-2.1.0.tgz", - "integrity": "sha512-ZMERYes6pDydyuGidse7OsHxtbI7WVeUEozgR/g7rd0xUimYNlvZRE/K2MgZTjWy725IfelLeVcEM97mmtRGXw==", - "dependencies": { - "binary-extensions": "^2.0.0" - }, - "engines": { - "node": ">=8" - } - }, - "node_modules/is-extglob": { - "version": "2.1.1", - "resolved": "https://registry.npmjs.org/is-extglob/-/is-extglob-2.1.1.tgz", - "integrity": "sha512-SbKbANkN603Vi4jEZv49LeVJMn4yGwsbzZworEoyEiutsN3nJYdbO36zfhGJ6QEDpOZIFkDtnq5JRxmvl3jsoQ==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-glob": { - "version": "4.0.3", - "resolved": "https://registry.npmjs.org/is-glob/-/is-glob-4.0.3.tgz", - "integrity": "sha512-xelSayHH36ZgE7ZWhli7pW34hNbNl8Ojv5KVmkJD4hBdD3th8Tfk9vYasLM+mXWOZhFkgZfxhLSnrwRr4elSSg==", - "dependencies": { - "is-extglob": "^2.1.1" - }, - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/is-number": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/is-number/-/is-number-7.0.0.tgz", - "integrity": "sha512-41Cifkg6e8TylSpdtTpeLVMqvSBEVzTttHvERD741+pnZ8ANv0004MRL43QKPDlK9cGvNp6NZWZUBlbGXYxxng==", - "engines": { - "node": ">=0.12.0" - } - }, - "node_modules/jsonwebtoken": { - "version": "9.0.2", - "resolved": "https://registry.npmjs.org/jsonwebtoken/-/jsonwebtoken-9.0.2.tgz", - "integrity": "sha512-PRp66vJ865SSqOlgqS8hujT5U4AOgMfhrwYIuIhfKaoSCZcirrmASQr8CX7cUg+RMih+hgznrjp99o+W4pJLHQ==", - "dependencies": { - "jws": "^3.2.2", - "lodash.includes": "^4.3.0", - "lodash.isboolean": "^3.0.3", - "lodash.isinteger": "^4.0.4", - "lodash.isnumber": "^3.0.3", - "lodash.isplainobject": "^4.0.6", - "lodash.isstring": "^4.0.1", - "lodash.once": "^4.0.0", - "ms": "^2.1.1", - "semver": "^7.5.4" - }, - "engines": { - "node": ">=12", - "npm": ">=6" - } - }, - "node_modules/jsonwebtoken/node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" - }, - "node_modules/jwa": { - "version": "1.4.1", - "resolved": "https://registry.npmjs.org/jwa/-/jwa-1.4.1.tgz", - "integrity": "sha512-qiLX/xhEEFKUAJ6FiBMbes3w9ATzyk5W7Hvzpa/SLYdxNtng+gcurvrI7TbACjIXlsJyr05/S1oUhZrc63evQA==", - "dependencies": { - "buffer-equal-constant-time": "1.0.1", - "ecdsa-sig-formatter": "1.0.11", - "safe-buffer": "^5.0.1" - } - }, - "node_modules/jws": { - "version": "3.2.2", - "resolved": "https://registry.npmjs.org/jws/-/jws-3.2.2.tgz", - "integrity": "sha512-YHlZCB6lMTllWDtSPHz/ZXTsi8S00usEV6v1tjq8tOUZzw7DpSDWVXjXDre6ed1w/pd495ODpHZYSdkRTsa0HA==", - "dependencies": { - "jwa": "^1.4.1", - "safe-buffer": "^5.0.1" - } - }, - "node_modules/kareem": { - "version": "2.6.3", - "resolved": "https://registry.npmjs.org/kareem/-/kareem-2.6.3.tgz", - "integrity": "sha512-C3iHfuGUXK2u8/ipq9LfjFfXFxAZMQJJq7vLS45r3D9Y2xQ/m4S8zaR4zMLFWh9AsNPXmcFfUDhTEO8UIC/V6Q==", - "engines": { - "node": ">=12.0.0" - } - }, - "node_modules/lodash.includes": { - "version": "4.3.0", - "resolved": "https://registry.npmjs.org/lodash.includes/-/lodash.includes-4.3.0.tgz", - "integrity": "sha512-W3Bx6mdkRTGtlJISOvVD/lbqjTlPPUDTMnlXZFnVwi9NKJ6tiAk6LVdlhZMm17VZisqhKcgzpO5Wz91PCt5b0w==" - }, - "node_modules/lodash.isboolean": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/lodash.isboolean/-/lodash.isboolean-3.0.3.tgz", - "integrity": "sha512-Bz5mupy2SVbPHURB98VAcw+aHh4vRV5IPNhILUCsOzRmsTmSQ17jIuqopAentWoehktxGd9e/hbIXq980/1QJg==" - }, - "node_modules/lodash.isinteger": { - "version": "4.0.4", - "resolved": "https://registry.npmjs.org/lodash.isinteger/-/lodash.isinteger-4.0.4.tgz", - "integrity": "sha512-DBwtEWN2caHQ9/imiNeEA5ys1JoRtRfY3d7V9wkqtbycnAmTvRRmbHKDV4a0EYc678/dia0jrte4tjYwVBaZUA==" - }, - "node_modules/lodash.isnumber": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/lodash.isnumber/-/lodash.isnumber-3.0.3.tgz", - "integrity": "sha512-QYqzpfwO3/CWf3XP+Z+tkQsfaLL/EnUlXWVkIk5FUPc4sBdTehEqZONuyRt2P67PXAk+NXmTBcc97zw9t1FQrw==" - }, - "node_modules/lodash.isplainobject": { - "version": "4.0.6", - "resolved": "https://registry.npmjs.org/lodash.isplainobject/-/lodash.isplainobject-4.0.6.tgz", - "integrity": "sha512-oSXzaWypCMHkPC3NvBEaPHf0KsA5mvPrOPgQWDsbg8n7orZ290M0BmC/jgRZ4vcJ6DTAhjrsSYgdsW/F+MFOBA==" - }, - "node_modules/lodash.isstring": { - "version": "4.0.1", - "resolved": "https://registry.npmjs.org/lodash.isstring/-/lodash.isstring-4.0.1.tgz", - "integrity": "sha512-0wJxfxH1wgO3GrbuP+dTTk7op+6L41QCXbGINEmD+ny/G/eCqGzxyCsh7159S+mgDDcoarnBw6PC1PS5+wUGgw==" - }, - "node_modules/lodash.once": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/lodash.once/-/lodash.once-4.1.1.tgz", - "integrity": "sha512-Sb487aTOCr9drQVL8pIxOzVhafOjZN9UU54hiN8PU3uAiSV7lx1yYNpbNmex2PK6dSJoNTSJUUswT651yww3Mg==" - }, - "node_modules/media-typer": { - "version": "0.3.0", - "resolved": "https://registry.npmjs.org/media-typer/-/media-typer-0.3.0.tgz", - "integrity": "sha512-dq+qelQ9akHpcOl/gUVRTxVIOkAJ1wR3QAvb4RsVjS8oVoFjDGTc679wJYmUmknUF5HwMLOgb5O+a3KxfWapPQ==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/memory-pager": { - "version": "1.5.0", - "resolved": "https://registry.npmjs.org/memory-pager/-/memory-pager-1.5.0.tgz", - "integrity": "sha512-ZS4Bp4r/Zoeq6+NLJpP+0Zzm0pR8whtGPf1XExKLJBAczGMnSi3It14OiNCStjQjM6NU1okjQGSxgEZN8eBYKg==" - }, - "node_modules/merge-descriptors": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/merge-descriptors/-/merge-descriptors-1.0.1.tgz", - "integrity": "sha512-cCi6g3/Zr1iqQi6ySbseM1Xvooa98N0w31jzUYrXPX2xqObmFGHJ0tQ5u74H3mVh7wLouTseZyYIq39g8cNp1w==" - }, - "node_modules/methods": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/methods/-/methods-1.1.2.tgz", - "integrity": "sha512-iclAHeNqNm68zFtnZ0e+1L2yUIdvzNoauKU4WBA3VvH/vPFieF7qfRlwUZU+DA9P9bPXIS90ulxoUoCH23sV2w==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/mime": { - "version": "1.6.0", - "resolved": "https://registry.npmjs.org/mime/-/mime-1.6.0.tgz", - "integrity": "sha512-x0Vn8spI+wuJ1O6S7gnbaQg8Pxh4NNHb7KSINmEWKiPE4RKOplvijn+NkmYmmRgP68mc70j2EbeTFRsrswaQeg==", - "bin": { - "mime": "cli.js" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/mime-db": { - "version": "1.52.0", - "resolved": "https://registry.npmjs.org/mime-db/-/mime-db-1.52.0.tgz", - "integrity": "sha512-sPU4uV7dYlvtWJxwwxHD0PuihVNiE7TyAbQ5SWxDCB9mUYvOgroQOwYQQOKPJ8CIbE+1ETVlOoK1UC2nU3gYvg==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/mime-types": { - "version": "2.1.35", - "resolved": "https://registry.npmjs.org/mime-types/-/mime-types-2.1.35.tgz", - "integrity": "sha512-ZDY+bPm5zTTF+YpCrAU9nK0UgICYPT0QtT1NZWFv4s++TNkcgVaT0g6+4R2uI4MjQjzysHB1zxuWL50hzaeXiw==", - "dependencies": { - "mime-db": "1.52.0" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/minimatch": { - "version": "3.1.2", - "resolved": "https://registry.npmjs.org/minimatch/-/minimatch-3.1.2.tgz", - "integrity": "sha512-J7p63hRiAjw1NDEww1W7i37+ByIrOWO5XQQAzZ3VOcL0PNybwpfmV/N05zFAzwQ9USyEcX6t3UO+K5aqBQOIHw==", - "dependencies": { - "brace-expansion": "^1.1.7" - }, - "engines": { - "node": "*" - } - }, - "node_modules/mongodb": { - "version": "6.6.2", - "resolved": "https://registry.npmjs.org/mongodb/-/mongodb-6.6.2.tgz", - "integrity": "sha512-ZF9Ugo2JCG/GfR7DEb4ypfyJJyiKbg5qBYKRintebj8+DNS33CyGMkWbrS9lara+u+h+yEOGSRiLhFO/g1s1aw==", - "dependencies": { - "@mongodb-js/saslprep": "^1.1.5", - "bson": "^6.7.0", - "mongodb-connection-string-url": "^3.0.0" - }, - "engines": { - "node": ">=16.20.1" - }, - "peerDependencies": { - "@aws-sdk/credential-providers": "^3.188.0", - "@mongodb-js/zstd": "^1.1.0", - "gcp-metadata": "^5.2.0", - "kerberos": "^2.0.1", - "mongodb-client-encryption": ">=6.0.0 <7", - "snappy": "^7.2.2", - "socks": "^2.7.1" - }, - "peerDependenciesMeta": { - "@aws-sdk/credential-providers": { - "optional": true - }, - "@mongodb-js/zstd": { - "optional": true - }, - "gcp-metadata": { - "optional": true - }, - "kerberos": { - "optional": true - }, - "mongodb-client-encryption": { - "optional": true - }, - "snappy": { - "optional": true - }, - "socks": { - "optional": true - } - } - }, - "node_modules/mongodb-connection-string-url": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/mongodb-connection-string-url/-/mongodb-connection-string-url-3.0.1.tgz", - "integrity": "sha512-XqMGwRX0Lgn05TDB4PyG2h2kKO/FfWJyCzYQbIhXUxz7ETt0I/FqHjUeqj37irJ+Dl1ZtU82uYyj14u2XsZKfg==", - "dependencies": { - "@types/whatwg-url": "^11.0.2", - "whatwg-url": "^13.0.0" - } - }, - "node_modules/mongoose": { - "version": "8.4.1", - "resolved": "https://registry.npmjs.org/mongoose/-/mongoose-8.4.1.tgz", - "integrity": "sha512-odQ2WEWGL3hb0Qex+QMN4eH6D34WdMEw7F1If2MGABApSDmG9cMmqv/G1H6WsXmuaH9mkuuadW/WbLE5+tHJwA==", - "dependencies": { - "bson": "^6.7.0", - "kareem": "2.6.3", - "mongodb": "6.6.2", - "mpath": "0.9.0", - "mquery": "5.0.0", - "ms": "2.1.3", - "sift": "17.1.3" - }, - "engines": { - "node": ">=16.20.1" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/mongoose" - } - }, - "node_modules/mongoose/node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" - }, - "node_modules/mpath": { - "version": "0.9.0", - "resolved": "https://registry.npmjs.org/mpath/-/mpath-0.9.0.tgz", - "integrity": "sha512-ikJRQTk8hw5DEoFVxHG1Gn9T/xcjtdnOKIU1JTmGjZZlg9LST2mBLmcX3/ICIbgJydT2GOc15RnNy5mHmzfSew==", - "engines": { - "node": ">=4.0.0" - } - }, - "node_modules/mquery": { - "version": "5.0.0", - "resolved": "https://registry.npmjs.org/mquery/-/mquery-5.0.0.tgz", - "integrity": "sha512-iQMncpmEK8R8ncT8HJGsGc9Dsp8xcgYMVSbs5jgnm1lFHTZqMJTUWTDx1LBO8+mK3tPNZWFLBghQEIOULSTHZg==", - "dependencies": { - "debug": "4.x" - }, - "engines": { - "node": ">=14.0.0" - } - }, - "node_modules/mquery/node_modules/debug": { - "version": "4.3.5", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", - "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", - "dependencies": { - "ms": "2.1.2" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } - }, - "node_modules/mquery/node_modules/ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" - }, - "node_modules/ms": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.0.0.tgz", - "integrity": "sha512-Tpp60P6IUJDTuOq/5Z8cdskzJujfwqfOTkrwIwj7IRISpnkJnT6SyJ4PCPnGMoFjC9ddhal5KVIYtAt97ix05A==" - }, - "node_modules/negotiator": { - "version": "0.6.3", - "resolved": "https://registry.npmjs.org/negotiator/-/negotiator-0.6.3.tgz", - "integrity": "sha512-+EUsqGPLsM+j/zdChZjsnX51g4XrHFOIXwfnCVPGlQk/k5giakcKsuxCObBRu6DSm9opw/O6slWbJdghQM4bBg==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/nodemon": { - "version": "3.1.3", - "resolved": "https://registry.npmjs.org/nodemon/-/nodemon-3.1.3.tgz", - "integrity": "sha512-m4Vqs+APdKzDFpuaL9F9EVOF85+h070FnkHVEoU4+rmT6Vw0bmNl7s61VEkY/cJkL7RCv1p4urnUDUMrS5rk2w==", - "dependencies": { - "chokidar": "^3.5.2", - "debug": "^4", - "ignore-by-default": "^1.0.1", - "minimatch": "^3.1.2", - "pstree.remy": "^1.1.8", - "semver": "^7.5.3", - "simple-update-notifier": "^2.0.0", - "supports-color": "^5.5.0", - "touch": "^3.1.0", - "undefsafe": "^2.0.5" - }, - "bin": { - "nodemon": "bin/nodemon.js" - }, - "engines": { - "node": ">=10" - }, - "funding": { - "type": "opencollective", - "url": "https://opencollective.com/nodemon" - } - }, - "node_modules/nodemon/node_modules/debug": { - "version": "4.3.5", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", - "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", - "dependencies": { - "ms": "2.1.2" - }, - "engines": { - "node": ">=6.0" - }, - "peerDependenciesMeta": { - "supports-color": { - "optional": true - } - } - }, - "node_modules/nodemon/node_modules/ms": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.2.tgz", - "integrity": "sha512-sGkPx+VjMtmA6MX27oA4FBFELFCZZ4S4XqeGOXCv68tT+jb3vk/RyaKWP0PTKyWtmLSM0b+adUTEvbs1PEaH2w==" - }, - "node_modules/normalize-path": { - "version": "3.0.0", - "resolved": "https://registry.npmjs.org/normalize-path/-/normalize-path-3.0.0.tgz", - "integrity": "sha512-6eZs5Ls3WtCisHWp9S2GUy8dqkpGi4BVSz3GaqiE6ezub0512ESztXUwUB6C6IKbQkY2Pnb/mD4WYojCRwcwLA==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/object-assign": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/object-assign/-/object-assign-4.1.1.tgz", - "integrity": "sha512-rJgTQnkUnH1sFw8yT6VSU3zD3sWmu6sZhIseY8VX+GRu3P6F7Fu+JNDoXfklElbLJSnc3FUQHVe4cU5hj+BcUg==", - "engines": { - "node": ">=0.10.0" - } - }, - "node_modules/object-inspect": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", - "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/on-finished": { - "version": "2.4.1", - "resolved": "https://registry.npmjs.org/on-finished/-/on-finished-2.4.1.tgz", - "integrity": "sha512-oVlzkg3ENAhCk2zdv7IJwd/QUD4z2RxRwpkcGY8psCVcCYZNq4wYnVWALHM+brtuJjePWiYF/ClmuDr8Ch5+kg==", - "dependencies": { - "ee-first": "1.1.1" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/parseurl": { - "version": "1.3.3", - "resolved": "https://registry.npmjs.org/parseurl/-/parseurl-1.3.3.tgz", - "integrity": "sha512-CiyeOxFT/JZyN5m0z9PfXw4SCBJ6Sygz1Dpl0wqjlhDEGGBP1GnsUVEL0p63hoG1fcj3fHynXi9NYO4nWOL+qQ==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/path-to-regexp": { - "version": "0.1.7", - "resolved": "https://registry.npmjs.org/path-to-regexp/-/path-to-regexp-0.1.7.tgz", - "integrity": "sha512-5DFkuoqlv1uYQKxy8omFBeJPQcdoE07Kv2sferDCrAq1ohOU+MSDswDIbnx3YAM60qIOnYa53wBhXW0EbMonrQ==" - }, - "node_modules/picomatch": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/picomatch/-/picomatch-2.3.1.tgz", - "integrity": "sha512-JU3teHTNjmE2VCGFzuY8EXzCDVwEqB2a8fsIvwaStHhAWJEeVd1o1QD80CU6+ZdEXXSLbSsuLwJjkCBWqRQUVA==", - "engines": { - "node": ">=8.6" - }, - "funding": { - "url": "https://github.com/sponsors/jonschlinkert" - } - }, - "node_modules/proxy-addr": { - "version": "2.0.7", - "resolved": "https://registry.npmjs.org/proxy-addr/-/proxy-addr-2.0.7.tgz", - "integrity": "sha512-llQsMLSUDUPT44jdrU/O37qlnifitDP+ZwrmmZcoSKyLKvtZxpyV0n2/bD/N4tBAAZ/gJEdZU7KMraoK1+XYAg==", - "dependencies": { - "forwarded": "0.2.0", - "ipaddr.js": "1.9.1" - }, - "engines": { - "node": ">= 0.10" - } - }, - "node_modules/pstree.remy": { - "version": "1.1.8", - "resolved": "https://registry.npmjs.org/pstree.remy/-/pstree.remy-1.1.8.tgz", - "integrity": "sha512-77DZwxQmxKnu3aR542U+X8FypNzbfJ+C5XQDk3uWjWxn6151aIMGthWYRXTqT1E5oJvg+ljaa2OJi+VfvCOQ8w==" - }, - "node_modules/punycode": { - "version": "2.3.1", - "resolved": "https://registry.npmjs.org/punycode/-/punycode-2.3.1.tgz", - "integrity": "sha512-vYt7UD1U9Wg6138shLtLOvdAu+8DsC/ilFtEVHcH+wydcSpNE20AfSOduf6MkRFahL5FY7X1oU7nKVZFtfq8Fg==", - "engines": { - "node": ">=6" - } - }, - "node_modules/qs": { - "version": "6.11.0", - "resolved": "https://registry.npmjs.org/qs/-/qs-6.11.0.tgz", - "integrity": "sha512-MvjoMCJwEarSbUYk5O+nmoSzSutSsTwF85zcHPQ9OrlFoZOYIjaqBAJIqIXjptyD5vThxGq52Xu/MaJzRkIk4Q==", - "dependencies": { - "side-channel": "^1.0.4" - }, - "engines": { - "node": ">=0.6" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/range-parser": { - "version": "1.2.1", - "resolved": "https://registry.npmjs.org/range-parser/-/range-parser-1.2.1.tgz", - "integrity": "sha512-Hrgsx+orqoygnmhFbKaHE6c296J+HTAQXoxEF6gNupROmmGJRoyzfG3ccAveqCBrwr/2yxQ5BVd/GTl5agOwSg==", - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/raw-body": { - "version": "2.5.2", - "resolved": "https://registry.npmjs.org/raw-body/-/raw-body-2.5.2.tgz", - "integrity": "sha512-8zGqypfENjCIqGhgXToC8aB2r7YrBX+AQAfIPs/Mlk+BtPTztOvTS01NRW/3Eh60J+a48lt8qsCzirQ6loCVfA==", - "dependencies": { - "bytes": "3.1.2", - "http-errors": "2.0.0", - "iconv-lite": "0.4.24", - "unpipe": "1.0.0" - }, - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/readdirp": { - "version": "3.6.0", - "resolved": "https://registry.npmjs.org/readdirp/-/readdirp-3.6.0.tgz", - "integrity": "sha512-hOS089on8RduqdbhvQ5Z37A0ESjsqz6qnRcffsMU3495FuTdqSm+7bhJ29JvIOsBDEEnan5DPu9t3To9VRlMzA==", - "dependencies": { - "picomatch": "^2.2.1" - }, - "engines": { - "node": ">=8.10.0" - } - }, - "node_modules/safe-buffer": { - "version": "5.2.1", - "resolved": "https://registry.npmjs.org/safe-buffer/-/safe-buffer-5.2.1.tgz", - "integrity": "sha512-rp3So07KcdmmKbGvgaNxQSJr7bGVSVk5S9Eq1F+ppbRo70+YeaDxkw5Dd8NPN+GD6bjnYm2VuPuCXmpuYvmCXQ==", - "funding": [ - { - "type": "github", - "url": "https://github.com/sponsors/feross" - }, - { - "type": "patreon", - "url": "https://www.patreon.com/feross" - }, - { - "type": "consulting", - "url": "https://feross.org/support" - } - ] - }, - "node_modules/safer-buffer": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/safer-buffer/-/safer-buffer-2.1.2.tgz", - "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" - }, - "node_modules/semver": { - "version": "7.6.2", - "resolved": "https://registry.npmjs.org/semver/-/semver-7.6.2.tgz", - "integrity": "sha512-FNAIBWCx9qcRhoHcgcJ0gvU7SN1lYU2ZXuSfl04bSC5OpvDHFyJCjdNHomPXxjQlCBU67YW64PzY7/VIEH7F2w==", - "bin": { - "semver": "bin/semver.js" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/send": { - "version": "0.18.0", - "resolved": "https://registry.npmjs.org/send/-/send-0.18.0.tgz", - "integrity": "sha512-qqWzuOjSFOuqPjFe4NOsMLafToQQwBSOEpS+FwEt3A2V3vKubTquT3vmLTQpFgMXp8AlFWFuP1qKaJZOtPpVXg==", - "dependencies": { - "debug": "2.6.9", - "depd": "2.0.0", - "destroy": "1.2.0", - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "etag": "~1.8.1", - "fresh": "0.5.2", - "http-errors": "2.0.0", - "mime": "1.6.0", - "ms": "2.1.3", - "on-finished": "2.4.1", - "range-parser": "~1.2.1", - "statuses": "2.0.1" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/send/node_modules/ms": { - "version": "2.1.3", - "resolved": "https://registry.npmjs.org/ms/-/ms-2.1.3.tgz", - "integrity": "sha512-6FlzubTLZG3J2a/NVCAleEhjzq5oxgHyaCU9yYXvcLsvoVaHJq/s5xXI6/XXP6tz7R9xAOtHnSO/tXtF3WRTlA==" - }, - "node_modules/serve-static": { - "version": "1.15.0", - "resolved": "https://registry.npmjs.org/serve-static/-/serve-static-1.15.0.tgz", - "integrity": "sha512-XGuRDNjXUijsUL0vl6nSD7cwURuzEgglbOaFuZM9g3kwDXOWVTck0jLzjPzGD+TazWbboZYu52/9/XPdUgne9g==", - "dependencies": { - "encodeurl": "~1.0.2", - "escape-html": "~1.0.3", - "parseurl": "~1.3.3", - "send": "0.18.0" - }, - "engines": { - "node": ">= 0.8.0" - } - }, - "node_modules/set-function-length": { - "version": "1.2.2", - "resolved": "https://registry.npmjs.org/set-function-length/-/set-function-length-1.2.2.tgz", - "integrity": "sha512-pgRc4hJ4/sNjWCSS9AmnS40x3bNMDTknHgL5UaMBTMyJnU90EgWh1Rz+MC9eFu4BuN/UwZjKQuY/1v3rM7HMfg==", - "dependencies": { - "define-data-property": "^1.1.4", - "es-errors": "^1.3.0", - "function-bind": "^1.1.2", - "get-intrinsic": "^1.2.4", - "gopd": "^1.0.1", - "has-property-descriptors": "^1.0.2" - }, - "engines": { - "node": ">= 0.4" - } - }, - "node_modules/setprototypeof": { - "version": "1.2.0", - "resolved": "https://registry.npmjs.org/setprototypeof/-/setprototypeof-1.2.0.tgz", - "integrity": "sha512-E5LDX7Wrp85Kil5bhZv46j8jOeboKq5JMmYM3gVGdGH8xFpPWXUMsNrlODCrkoxMEeNi/XZIwuRvY4XNwYMJpw==" - }, - "node_modules/side-channel": { - "version": "1.0.6", - "resolved": "https://registry.npmjs.org/side-channel/-/side-channel-1.0.6.tgz", - "integrity": "sha512-fDW/EZ6Q9RiO8eFG8Hj+7u/oW+XrPTIChwCOM2+th2A6OblDtYYIpve9m+KvI9Z4C9qSEXlaGR6bTEYHReuglA==", - "dependencies": { - "call-bind": "^1.0.7", - "es-errors": "^1.3.0", - "get-intrinsic": "^1.2.4", - "object-inspect": "^1.13.1" - }, - "engines": { - "node": ">= 0.4" - }, - "funding": { - "url": "https://github.com/sponsors/ljharb" - } - }, - "node_modules/sift": { - "version": "17.1.3", - "resolved": "https://registry.npmjs.org/sift/-/sift-17.1.3.tgz", - "integrity": "sha512-Rtlj66/b0ICeFzYTuNvX/EF1igRbbnGSvEyT79McoZa/DeGhMyC5pWKOEsZKnpkqtSeovd5FL/bjHWC3CIIvCQ==" - }, - "node_modules/simple-update-notifier": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/simple-update-notifier/-/simple-update-notifier-2.0.0.tgz", - "integrity": "sha512-a2B9Y0KlNXl9u/vsW6sTIu9vGEpfKu2wRV6l1H3XEas/0gUIzGzBoP/IouTcUQbm9JWZLH3COxyn03TYlFax6w==", - "dependencies": { - "semver": "^7.5.3" - }, - "engines": { - "node": ">=10" - } - }, - "node_modules/sparse-bitfield": { - "version": "3.0.3", - "resolved": "https://registry.npmjs.org/sparse-bitfield/-/sparse-bitfield-3.0.3.tgz", - "integrity": "sha512-kvzhi7vqKTfkh0PZU+2D2PIllw2ymqJKujUcyPMd9Y75Nv4nPbGJZXNhxsgdQab2BmlDct1YnfQCguEvHr7VsQ==", - "dependencies": { - "memory-pager": "^1.0.2" - } - }, - "node_modules/statuses": { - "version": "2.0.1", - "resolved": "https://registry.npmjs.org/statuses/-/statuses-2.0.1.tgz", - "integrity": "sha512-RwNA9Z/7PrK06rYLIzFMlaF+l73iwpzsqRIFgbMLbTcLD6cOao82TaWefPXQvB2fOC4AjuYSEndS7N/mTCbkdQ==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/supports-color": { - "version": "5.5.0", - "resolved": "https://registry.npmjs.org/supports-color/-/supports-color-5.5.0.tgz", - "integrity": "sha512-QjVjwdXIt408MIiAqCX4oUKsgU2EqAGzs2Ppkm4aQYbjm+ZEWEcW4SfFNTr4uMNZma0ey4f5lgLrkB0aX0QMow==", - "dependencies": { - "has-flag": "^3.0.0" - }, - "engines": { - "node": ">=4" - } - }, - "node_modules/to-regex-range": { - "version": "5.0.1", - "resolved": "https://registry.npmjs.org/to-regex-range/-/to-regex-range-5.0.1.tgz", - "integrity": "sha512-65P7iz6X5yEr1cwcgvQxbbIw7Uk3gOy5dIdtZ4rDveLqhrdJP+Li/Hx6tyK0NEb+2GCyneCMJiGqrADCSNk8sQ==", - "dependencies": { - "is-number": "^7.0.0" - }, - "engines": { - "node": ">=8.0" - } - }, - "node_modules/toidentifier": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/toidentifier/-/toidentifier-1.0.1.tgz", - "integrity": "sha512-o5sSPKEkg/DIQNmH43V0/uerLrpzVedkUh8tGNvaeXpfpuwjKenlSox/2O/BTlZUtEe+JG7s5YhEz608PlAHRA==", - "engines": { - "node": ">=0.6" - } - }, - "node_modules/touch": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/touch/-/touch-3.1.1.tgz", - "integrity": "sha512-r0eojU4bI8MnHr8c5bNo7lJDdI2qXlWWJk6a9EAFG7vbhTjElYhBVS3/miuE0uOuoLdb8Mc/rVfsmm6eo5o9GA==", - "bin": { - "nodetouch": "bin/nodetouch.js" - } - }, - "node_modules/tr46": { - "version": "4.1.1", - "resolved": "https://registry.npmjs.org/tr46/-/tr46-4.1.1.tgz", - "integrity": "sha512-2lv/66T7e5yNyhAAC4NaKe5nVavzuGJQVVtRYLyQ2OI8tsJ61PMLlelehb0wi2Hx6+hT/OJUWZcw8MjlSRnxvw==", - "dependencies": { - "punycode": "^2.3.0" - }, - "engines": { - "node": ">=14" - } - }, - "node_modules/type-is": { - "version": "1.6.18", - "resolved": "https://registry.npmjs.org/type-is/-/type-is-1.6.18.tgz", - "integrity": "sha512-TkRKr9sUTxEH8MdfuCSP7VizJyzRNMjj2J2do2Jr3Kym598JVdEksuzPQCnlFPW4ky9Q+iA+ma9BGm06XQBy8g==", - "dependencies": { - "media-typer": "0.3.0", - "mime-types": "~2.1.24" - }, - "engines": { - "node": ">= 0.6" - } - }, - "node_modules/undefsafe": { - "version": "2.0.5", - "resolved": "https://registry.npmjs.org/undefsafe/-/undefsafe-2.0.5.tgz", - "integrity": "sha512-WxONCrssBM8TSPRqN5EmsjVrsv4A8X12J4ArBiiayv3DyyG3ZlIg6yysuuSYdZsVz3TKcTg2fd//Ujd4CHV1iA==" - }, - "node_modules/unpipe": { - "version": "1.0.0", - "resolved": "https://registry.npmjs.org/unpipe/-/unpipe-1.0.0.tgz", - "integrity": "sha512-pjy2bYhSsufwWlKwPc+l3cN7+wuJlK6uz0YdJEOlQDbl6jo/YlPi4mb8agUkVC8BF7V8NuzeyPNqRksA3hztKQ==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/utils-merge": { - "version": "1.0.1", - "resolved": "https://registry.npmjs.org/utils-merge/-/utils-merge-1.0.1.tgz", - "integrity": "sha512-pMZTvIkT1d+TFGvDOqodOclx0QWkkgi6Tdoa8gC8ffGAAqz9pzPTZWAybbsHHoED/ztMtkv/VoYTYyShUn81hA==", - "engines": { - "node": ">= 0.4.0" - } - }, - "node_modules/vary": { - "version": "1.1.2", - "resolved": "https://registry.npmjs.org/vary/-/vary-1.1.2.tgz", - "integrity": "sha512-BNGbWLfd0eUPabhkXUVm0j8uuvREyTh5ovRa/dyow/BqAbZJyC+5fU+IzQOzmAKzYqYRAISoRhdQr3eIZ/PXqg==", - "engines": { - "node": ">= 0.8" - } - }, - "node_modules/webidl-conversions": { - "version": "7.0.0", - "resolved": "https://registry.npmjs.org/webidl-conversions/-/webidl-conversions-7.0.0.tgz", - "integrity": "sha512-VwddBukDzu71offAQR975unBIGqfKZpM+8ZX6ySk8nYhVoo5CYaZyzt3YBvYtRtO+aoGlqxPg/B87NGVZ/fu6g==", - "engines": { - "node": ">=12" - } - }, - "node_modules/whatwg-url": { - "version": "13.0.0", - "resolved": "https://registry.npmjs.org/whatwg-url/-/whatwg-url-13.0.0.tgz", - "integrity": "sha512-9WWbymnqj57+XEuqADHrCJ2eSXzn8WXIW/YSGaZtb2WKAInQ6CHfaUUcTyyver0p8BDg5StLQq8h1vtZuwmOig==", - "dependencies": { - "tr46": "^4.1.1", - "webidl-conversions": "^7.0.0" - }, - "engines": { - "node": ">=16" - } - } - } -} diff --git a/backend/package.json b/backend/package.json deleted file mode 100644 index dbb85c1f4..000000000 --- a/backend/package.json +++ /dev/null @@ -1,22 +0,0 @@ -{ - "name": "backend", - "version": "1.0.0", - "main": "index.js", - "scripts": { - "start": "nodemon index.js", - "test": "echo \"Error: no test specified\" && exit 1" - }, - "keywords": [], - "author": "", - "license": "ISC", - "description": "", - "dependencies": { - "bcryptjs": "^2.4.3", - "body-parser": "^1.20.2", - "cors": "^2.8.5", - "express": "^4.19.2", - "jsonwebtoken": "^9.0.2", - "mongoose": "^8.4.1", - "nodemon": "^3.1.3" - } -} diff --git a/backend/routers/auth.js b/backend/routers/auth.js deleted file mode 100644 index f12433479..000000000 --- a/backend/routers/auth.js +++ /dev/null @@ -1,9 +0,0 @@ -// routes/auth.js -const express = require('express'); -const router = express.Router(); -const authController = require('../controllers/authController'); - -router.post('/signup', authController.signup); -router.post('/login', authController.login); - -module.exports = router; diff --git a/backend/routers/router.js b/backend/routers/router.js deleted file mode 100644 index dab572a37..000000000 --- a/backend/routers/router.js +++ /dev/null @@ -1,8 +0,0 @@ -// routes/router.js -const express = require('express'); -const router = express.Router(); -const authRoutes = require('./auth'); - -router.use('/auth', authRoutes); - -module.exports = router; diff --git a/blog/2021-06-15-dynamic-programming/dynamic-programming-problems.md b/blog/2021-06-15-dynamic-programming/dynamic-programming-problems.md deleted file mode 100644 index 4a1852227..000000000 --- a/blog/2021-06-15-dynamic-programming/dynamic-programming-problems.md +++ /dev/null @@ -1,36 +0,0 @@ ---- -slug: dynamic-programming-problems -title: Dynamic Programming Problems -authors: [Anshika] -tags: ["30daysofcpp", "arrays", "practice-problems","leetcode","geeksforgeeks"] ---- - -- [Maximum Subarray](https://leetcode.com/problems/maximum-subarray/description/) - -- [Valid Parenthesis String](https://leetcode.com/problems/valid-parenthesis-string/description/) - -- [Minimum Number of Operations to Satisfy Conditions](https://leetcode.com/problems/minimum-number-of-operations-to-satisfy-conditions/description/) - -- [N-th Tribonacci Number](https://leetcode.com/problems/n-th-tribonacci-number/description/) - -- [Is Subsequence](https://leetcode.com/problems/is-subsequence/description/) - -- [Counting Bits](https://leetcode.com/problems/counting-bits/description/) - -- [Best Time to Buy and Sell Stock](https://leetcode.com/problems/best-time-to-buy-and-sell-stock/description/) - -- [Pascal's Triangle](https://leetcode.com/problems/pascals-triangle/description/) - -- [Climbing Stairs](https://leetcode.com/problems/climbing-stairs/description/) - -- [Maximum Product Subarray](https://www.geeksforgeeks.org/problems/maximum-product-subarray3604/1?page=1&category=Dynamic%20Programming&sortBy=submissions) - -- [Perfect Sum Problem](https://www.geeksforgeeks.org/problems/perfect-sum-problem5633/1?page=1&category=Dynamic%20Programming&sortBy=submissions) - -- [Subset Sum Problem](https://www.geeksforgeeks.org/problems/subset-sum-problem-1611555638/1?page=1&category=Dynamic%20Programming&sortBy=submissions) - -- [Minimum sum partition](https://www.geeksforgeeks.org/problems/minimum-sum-partition3317/1?page=2&category=Dynamic%20Programming&sortBy=submissions) - -- [Nth catalan numbe](https://www.geeksforgeeks.org/problems/nth-catalan-number0817/1?page=2&category=Dynamic%20Programming&sortBy=submissions) - -- [Word Break](https://www.geeksforgeeks.org/problems/word-break1352/1?page=2&category=Dynamic%20Programming&sortBy=submissions) diff --git a/blog/2021-08-01-mdx-blog-post.mdx b/blog/2021-08-01-mdx-blog-post.mdx deleted file mode 100644 index 7dcdf78f8..000000000 --- a/blog/2021-08-01-mdx-blog-post.mdx +++ /dev/null @@ -1,20 +0,0 @@ ---- -slug: mdx-blog-post -title: MDX Blog Post -authors: [shubhadip] -tags: [docusaurus] ---- - -Blog posts support [Docusaurus Markdown features](https://docusaurus.io/docs/markdown-features), such as [MDX](https://mdxjs.com/). - -:::tip - -Use the power of React to create interactive blog posts. - -```js -<button onClick={() => alert('button clicked!')}>Click me!</button> -``` - -<button onClick={() => alert('button clicked!')}>Click me!</button> - -::: diff --git a/blog/2024-05-23-hello-world/docusaurus-plushie-banner.jpeg b/blog/2024-05-23-hello-world/docusaurus-plushie-banner.jpeg deleted file mode 100644 index 11bda0928..000000000 Binary files a/blog/2024-05-23-hello-world/docusaurus-plushie-banner.jpeg and /dev/null differ diff --git a/blog/2024-05-23-hello-world/index.md b/blog/2024-05-23-hello-world/index.md deleted file mode 100644 index 0c0383fd1..000000000 --- a/blog/2024-05-23-hello-world/index.md +++ /dev/null @@ -1,11 +0,0 @@ ---- -slug: hello-world -title: Hello World -authors: [shubhadip] -tags: ["30daysofcpp", "first-blog", "opensource"] ---- - -## Hello World - -Hi, folks. -My name is Shubhadip and I am a student at Chandigarh University. I am a beginner in open source and I am participating in the #30DaysOfC++ challenge. I am excited to learn and contribute to open source. I will be sharing my journey through this blog. Stay tuned for more updates. diff --git a/blog/2024-06-03-STL-problems/STL-problems.md b/blog/2024-06-03-STL-problems/STL-problems.md deleted file mode 100644 index a1ab3672d..000000000 --- a/blog/2024-06-03-STL-problems/STL-problems.md +++ /dev/null @@ -1,27 +0,0 @@ ---- -slug: stl-problems -title: STL Problems -authors: [chaitanya] -tags: ["30daysofcpp", "standard-template-library", "vectors", "sets", "maps","practice-problems","codeforces","hackerrank","geeksforgeeks","spoj"] ---- - -- [Vector-STL](https://www.geeksforgeeks.org/problems/c-stl-set-1-vector/1) - -- [Sets-STL](https://www.hackerrank.com/challenges/cpp-sets/problem) - -- [Map-STL](https://www.hackerrank.com/challenges/cpp-maps/problem) - -- [Tom Riddle's Diary](https://codeforces.com/contest/855/problem/A) - -- [Find the frequency](https://www.geeksforgeeks.org/problems/find-the-frequency/1) - -- [Pretty Print](https://www.hackerrank.com/challenges/prettyprint/problem?isFullScreen=true) - -- [Twice Counter](https://www.geeksforgeeks.org/problems/twice-counter4236/1) - -- [Radio Station](https://codeforces.com/contest/918/problem/B) - -- [Dequeue-STL](https://www.hackerrank.com/challenges/deque-stl/problem) - -- [RPLD Database](https://www.spoj.com/problems/RPLD/) - diff --git a/blog/2024-06-03-array-problems/array-problems.md b/blog/2024-06-03-array-problems/array-problems.md deleted file mode 100644 index 5e0f3c8e2..000000000 --- a/blog/2024-06-03-array-problems/array-problems.md +++ /dev/null @@ -1,62 +0,0 @@ ---- -slug: array-problems -title: Array Problems -authors: [chaitanya] -tags: ["30daysofcpp", "arrays", "practice-problems","leetcode","hackerrank","geeksforgeeks","edabit"] ---- - -- [Array Introduction](https://www.hackerrank.com/challenges/arrays-introduction/problem?isFullScreen=true) - -- [Index Multiplier](https://edabit.com/challenge/QcDeF47azy5bhPos6) - -- [2D array](https://www.geeksforgeeks.org/problems/two-dimensional-world/1) - -- [Perfect Square Patch](https://edabit.com/challenge/omTRzwvBibk4etBkx) - -- [Merge two arrays](https://www.geeksforgeeks.org/problems/merge-two-sorted-arrays-1587115620/1) - -- [Peak Element](https://www.geeksforgeeks.org/problems/peak-element/1) - -- [Eliminate the odds](https://edabit.com/challenge/7iT6DbY3GsHnLBPq4) - -- [Variable Sized Array](https://www.hackerrank.com/challenges/variable-sized-arrays/problem?isFullScreen=true) - -- [Check if sorted](https://leetcode.com/problems/check-if-array-is-sorted-and-rotated/description/) - -- [Best time to buy and sell stock](https://leetcode.com/problems/best-time-to-buy-and-sell-stock/description/) - -- [Search for the element](https://www.geeksforgeeks.org/problems/who-will-win-1587115621/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=who-will-win) - -- [Majority Element](https://leetcode.com/problems/majority-element/description/) - -- [Trapping rainwater](https://www.geeksforgeeks.org/problems/trapping-rain-water-1587115621/1) - -- [Pascal's Triangle](https://leetcode.com/problems/pascals-triangle/description/) - -- [Count Inversion](https://www.geeksforgeeks.org/problems/inversion-of-array-1587115620/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=inversion-of-array) - -- [Concatenation of Array](https://leetcode.com/problems/concatenation-of-array/description/) - -- [Build Array from Permutation](https://leetcode.com/problems/build-array-from-permutation/description/) - -- [Number of Good Pairs](https://leetcode.com/problems/number-of-good-pairs/description/) - -- [Shuffle the Array](https://leetcode.com/problems/shuffle-the-array/description/) - -- [Largest Local Values in a Matrix](https://leetcode.com/problems/largest-local-values-in-a-matrix/description/) - -- [Convert an Array Into a 2D Array With Conditions](https://leetcode.com/problems/convert-an-array-into-a-2d-array-with-conditions/description/) - -- [Running Sum of 1d Array](https://leetcode.com/problems/running-sum-of-1d-array/description/) - -- [Decode XORed Array](https://leetcode.com/problems/decode-xored-array/description/) - -- [Check If Two String Arrays are Equivalent](https://leetcode.com/problems/check-if-two-string-arrays-are-equivalent/description/) - -- [Maximum Product Difference Between Two Pairs](https://leetcode.com/problems/maximum-product-difference-between-two-pairs/description/) - -- [Maximum Product of Two Elements in an Array](https://leetcode.com/problems/maximum-product-of-two-elements-in-an-array/description/) - -- [Height Checker](https://leetcode.com/problems/height-checker/description/) - -- [Unique Morse Code Words](https://leetcode.com/problems/unique-morse-code-words/description/) \ No newline at end of file diff --git a/blog/2024-06-03-control-structure-problems/control-structure-problems.md b/blog/2024-06-03-control-structure-problems/control-structure-problems.md deleted file mode 100644 index 29ca8ba7f..000000000 --- a/blog/2024-06-03-control-structure-problems/control-structure-problems.md +++ /dev/null @@ -1,43 +0,0 @@ ---- -slug: control-structure-problems -title: Control Structure Problems -authors: [chaitanya] -tags: ["30daysofcpp", "control-flow", "conditionals", "loops", "jump-controls","practice-problems","geeksforgeeks","codechef","edabit"] ---- - -## Conditionals - -- [Christmas? or not?](https://www.codechef.com/problems/CHRISTGREET) - -- [Find out how much the food costs](https://www.codechef.com/problems/FOODCOST) - -- [Equality of given numbers](https://edabit.com/challenge/uSiEPX7YrhNsqtzMr) - -- [Mango lassi](https://www.codechef.com/problems/MANGOLASSI) - -- [The farm problem](https://edabit.com/challenge/aADAoRtkbZWEKw9Ap) - -- [Reach on time](https://www.codechef.com/problems/TIMELY) - -- [Consonants and vowels](https://www.geeksforgeeks.org/problems/consonants-and-vowels-check/1) - -## Jump control - -- [Return number in words](https://www.geeksforgeeks.org/problems/c-switch-case-statement5900/1) - -## Loops - -- [Count the words](https://www.codechef.com/problems/CNTWRD) - -- [Reverse the digits](https://www.geeksforgeeks.org/problems/reverse-digit0316/1) - -- [LCM and GCD](https://www.geeksforgeeks.org/problems/lcm-and-gcd4516/1) - -- [Armstrong numbers](https://workat.tech/problem-solving/practice/armstrong-number) - -- [Palindrome numbers](https://www.geeksforgeeks.org/problems/palindrome0746/1) - -- [Prime numbers in range](https://www.geeksforgeeks.org/problems/find-prime-numbers-in-a-range4718/1) - -- [Patterns](https://www.geeksforgeeks.org/problems/pattern/1) - diff --git a/blog/2024-06-03-function-problems/function-problems.md b/blog/2024-06-03-function-problems/function-problems.md deleted file mode 100644 index 5ac1397ed..000000000 --- a/blog/2024-06-03-function-problems/function-problems.md +++ /dev/null @@ -1,90 +0,0 @@ ---- -slug: function-structure-problems -title: Function Problems -authors: [chaitanya] -tags: ["30daysofcpp", "functions", "practice-problems","leetcode","hackerrank","geeksforgeeks","codechef","edabit"] ---- - -- [Functions in Cpp](https://www.codechef.com/learn/course/cpp/LTCCPP27/problems/CPPFUNC01) - -- [User defined functions](https://www.codechef.com/learn/course/cpp/LTCCPP27/problems/CPPFUNC03) - -- [Function within a function](https://www.codechef.com/learn/course/cpp/LTCCPP27/problems/CPPFUNC08) - -- [Predefined functions](https://www.codechef.com/learn/course/cpp/LTCCPP27/problems/CPPFUNC09) - -- [Basic math functions](https://www.codechef.com/learn/course/cpp-beginner/BC00BC08/problems/BMMC08A) - -- [Repdigit or not](https://edabit.com/challenge/ciHft8ompLrYCyiEq) - -- [Sum of numbers](https://www.hackerrank.com/challenges/c-tutorial-functions/problem?isFullScreen=true) - -- [Prime Number](https://www.geeksforgeeks.org/problems/prime-number2314/1) - -- [Sum Of Digits](https://www.geeksforgeeks.org/problems/sum-of-digits1742/1) - -- [Coded words](https://edabit.com/challenge/7CaLzrWHhfzGw4CaT) - -- [Reverse and capitalize](https://edabit.com/challenge/mCfMS42XCvAGnH7q7) - -- [Compute with functions](https://www.codechef.com/learn/course/cpp/LTCCPP27/problems/CPPFUNC01) - -- [Print without loop](https://www.geeksforgeeks.org/problems/print-1-to-n-without-using-loops-1587115620/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=print-1-to-n-without-using-loops) - -- [Fibonacci Numnber](https://leetcode.com/problems/fibonacci-number/description/) - -- [Armstrong Numbers](https://www.geeksforgeeks.org/problems/armstrong-numbers2727/1) - -- [Factorial of numbers](https://www.geeksforgeeks.org/problems/find-all-factorial-numbers-less-than-or-equal-to-n3548/0?problemType=functional&difficulty%255B%255D=-1&page=1&query=problemTypefunctionaldifficulty%255B%255D-1page1) - -- [Anagram of String](https://www.geeksforgeeks.org/problems/anagram-of-string/1) - -- [Power of two](https://leetcode.com/problems/power-of-two/description/) - -- [Function Composition](https://leetcode.com/problems/function-composition/description/) - -- [Palindrome Number](https://leetcode.com/problems/palindrome-number/description/) - -- [The Palindrome Pattern](https://www.geeksforgeeks.org/problems/the-palindrome-pattern3900/1?page=1&category=Functions&sortBy=submissions) - -- [Compare the Triplets](https://www.hackerrank.com/challenges/compare-the-triplets/problem) - -- [A Very Big Sum](https://www.hackerrank.com/challenges/a-very-big-sum/problem) - -- [Sum of Digits](https://www.geeksforgeeks.org/problems/sum-of-digits-of-a-number-in-cpp/) - -- [Palindrome Number](https://leetcode.com/problems/palindrome-number/description/) - -- [Count Characters](https://edabit.com/challenge/et2Zbmb3bxdcm6xnf) - -- [Calculate Distance](https://www.hackerrank.com/challenges/kruskalmstrsub/problem) - -- [Generate Parentheses](https://leetcode.com/problems/generate-parentheses/description/) - -- [Maximum Prime Difference](https://leetcode.com/problems/maximum-prime-difference/description/) - -- [Sum of Digit Differences of All Pairs](https://leetcode.com/problems/sum-of-digit-differences-of-all-pairs/description/) - -- [Harshad Number](https://leetcode.com/problems/harshad-number/description/) - -- [Most Frequent Prime](https://leetcode.com/problems/most-frequent-prime/description/) - -- [Find Missing and Repeated Values](https://leetcode.com/problems/find-missing-and-repeated-values/description/) - -- [Maximum Xor Product](https://leetcode.com/problems/maximum-xor-product/description/) - -- [Maximum Odd Binary Number](https://leetcode.com/problems/maximum-odd-binary-number/description/) - -- [Check if The Number is Fascinating](https://leetcode.com/problems/check-if-the-number-is-fascinating/description/) - -- [Find the Pivot Integer](https://leetcode.com/problems/find-the-pivot-integer/description/) - -- [Sum of Number and Its Reverse](https://leetcode.com/problems/sum-of-number-and-its-reverse/description/) - -- [Find Triangular Sum of an Array](https://leetcode.com/problems/find-triangular-sum-of-an-array/description/) - -- [Count Square Sum Triples](https://leetcode.com/problems/count-square-sum-triples/description/) - - - - diff --git a/blog/2024-06-03-introductory-problems/introductory-problems.md b/blog/2024-06-03-introductory-problems/introductory-problems.md deleted file mode 100644 index de0c21602..000000000 --- a/blog/2024-06-03-introductory-problems/introductory-problems.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -slug: introductory-problems -title: Basic CPP Problems -authors: [chaitanya] -tags: ["30daysofcpp", "beginner", "operations", "input", "output","practice-problems","hackerrank","geeksforgeeks","codechef","edabit"] ---- - -- [Say "Hello World!" with C++](https://hackerrank.com/challenges/cpp-hello-world/problem?isFullScreen=true) - -- [Read and print an Integer](https://www.codechef.com/problems/START01) - -- [Add two numbers](https://edabit.com/challenge/SFzHtm63XT6EYNHWY) - -- [Find the Size of various data types](https://www.geeksforgeeks.org/problems/data-type-1666706751/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=data-type) - -- [Return next digit](https://edabit.com/challenge/QgCMMMyMmckvHbfKv) - -- [Convert Minutes into Seconds](https://edabit.com/challenge/MtNAJmJZ49i5Xf3AW) - -- [Maximum edge of a triangle](https://edabit.com/challenge/56XXwAkLJGbEccYfn) - -- [Clear day](https://www.codechef.com/problems/CLEARDAY) - -- [Double the rent](https://www.codechef.com/problems/DOUBLERENT) - diff --git a/blog/2024-06-03-sorting-problems/sorting-problems.md b/blog/2024-06-03-sorting-problems/sorting-problems.md deleted file mode 100644 index 6788437a1..000000000 --- a/blog/2024-06-03-sorting-problems/sorting-problems.md +++ /dev/null @@ -1,66 +0,0 @@ ---- -slug: sorting-problems -title: Sorting Problems -authors: [chaitanya] -tags: ["30daysofcpp", "sorting","practice-problems","leetcode","codeforces","geeksforgeeks"] ---- - -- [Gravity Flip](https://codeforces.com/problemset/problem/405/A) - -- [Honest Coach](https://codeforces.com/problemset/problem/1360/B) - -- [Selection Sort](https://www.geeksforgeeks.org/problems/selection-sort/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=selection-sort) - -- [Majority element](https://leetcode.com/problems/majority-element/description/) - -- [Bubble Sort](https://www.geeksforgeeks.org/problems/bubble-sort/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=bubble-sort) - -- [Quick Sort](https://www.geeksforgeeks.org/problems/quick-sort/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=quick-sort) - -- [Merge Sorted Array](https://leetcode.com/problems/merge-sorted-array/description/) - -- [Symmetric Encoding](https://codeforces.com/problemset/problem/1974/B) - -- [Insertion Sort](https://www.geeksforgeeks.org/problems/insertion-sort/0?category%5B%5D=Algorithms&page=1&query=category%5B%5DAlgorithmspage1&utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=insertion-sort) - -- [Sort Colors](https://leetcode.com/problems/sort-colors/description/) - -- [Find Players With Zero or One Losses](https://leetcode.com/problems/find-players-with-zero-or-one-losses/description/) - -- [Custom Sort String](https://leetcode.com/problems/custom-sort-string/description/) - -- [K Closest Points to Origin](https://leetcode.com/problems/k-closest-points-to-origin/description/) - -- [Minimum Number of Arrows to Burst Balloons](https://leetcode.com/problems/minimum-number-of-arrows-to-burst-balloons/description/) - -- [Bag of Tokens](https://leetcode.com/problems/bag-of-tokens/description/) - -- [Hand of Straights](https://leetcode.com/problems/hand-of-straights/description/) - -- [Determine if Two Strings Are Close](https://leetcode.com/problems/determine-if-two-strings-are-close/description/) - -- [Merge Intervals](https://leetcode.com/problems/merge-intervals/description/) - -- [3Sum](https://leetcode.com/problems/3sum/description/) - -- [Contains Duplicate](https://leetcode.com/problems/contains-duplicate/description/) - -- [Maximum Product of Three Numbers](https://leetcode.com/problems/maximum-product-of-three-numbers/description/) - -- [Set Mismatch](https://leetcode.com/problems/set-mismatch/description/) - -- [Relative Sort Array](https://leetcode.com/problems/relative-sort-array/description/) - -- [Array Partition](https://leetcode.com/problems/array-partition/description/) - -- [Relative Ranks](https://leetcode.com/problems/relative-ranks/description/) - -- [H-Index](https://leetcode.com/problems/h-index/description/) - -- [Largest Number](https://leetcode.com/problems/largest-number/description/) - -- [Meeting Rooms II](https://leetcode.com/problems/meeting-rooms-ii/description/) - -- [Wiggle Sort II](https://leetcode.com/problems/wiggle-sort-ii/description/) - -- [Sort Characters By Frequency](https://leetcode.com/problems/sort-characters-by-frequency/description/) \ No newline at end of file diff --git a/blog/2024-06-03-string-problems/string-problems.md b/blog/2024-06-03-string-problems/string-problems.md deleted file mode 100644 index 45747a226..000000000 --- a/blog/2024-06-03-string-problems/string-problems.md +++ /dev/null @@ -1,60 +0,0 @@ ---- -slug: string-problems -title: String Problems -authors: [chaitanya] -tags: ["30daysofcpp", "strings","practice-problems","leetcode","codeforces","geeksforgeeks","codechef","edabit"] ---- - -- [DNA Storage](https://www.codechef.com/practice/course/strings/STRINGS/problems/DNASTORAGE) - -- [Way too long words](https://codeforces.com/problemset/problem/71/A) - -- [Remove outermost parantheses](https://leetcode.com/problems/remove-outermost-parentheses/description/) - -- [Anagram](https://geeksforgeeks.org/problems/anagram-1587115620/1?page=1&category=Strings&sortBy=submissions) - -- [Verify Password](https://codeforces.com/contest/1976/problem/A) - -- [Blobby Volley Scores](https://www.codechef.com/practice/course/strings/STRINGS/problems/BLOBBYVOLLEY) - -- [Reverse every word in a string](https://leetcode.com/problems/reverse-words-in-a-string/description/) - -- [Dubstep](https://codeforces.com/problemset/problem/208/A) - -- [White Spaces](https://edabit.com/challenge/df9LtdceySMvqQJtW) - -- [Longest Common Prefix](https://leetcode.com/problems/longest-common-prefix/description/) - -- [Count number of substrings](https://www.geeksforgeeks.org/problems/count-number-of-substrings4528/1?utm_source=youtube&utm_medium=collab_striver_ytdescription&utm_campaign=count-number-of-substrings) - -- [Double Character Swap](https://edabit.com/challenge/s695FkhRd3J65tmdQ) - -- [Validate an IP Adress](https://www.geeksforgeeks.org/problems/validate-an-ip-address-1587115621/1?page=1&category=Strings&sortBy=submissions) - -- [String to Integer](https://leetcode.com/problems/string-to-integer-atoi/description/) - -- [Roman to Integer](https://leetcode.com/problems/roman-to-integer/description/) - -- [Sort Vowels in a String](https://leetcode.com/problems/sort-vowels-in-a-string/description/) - -- [Letter Tile Possibilities](https://leetcode.com/problems/letter-tile-possibilities/description/) - -- [Append Characters to String to Make Subsequence](https://leetcode.com/problems/append-characters-to-string-to-make-subsequence/description/) - -- [Custom Sort String](https://leetcode.com/problems/custom-sort-string/description/) - -- [Minimum Remove to Make Valid Parentheses](https://leetcode.com/problems/minimum-remove-to-make-valid-parentheses/description/) - -- [Letter Combinations of a Phone Number](https://leetcode.com/problems/letter-combinations-of-a-phone-number/description/) - -- [Maximum Product of Word Lengths](https://leetcode.com/problems/maximum-product-of-word-lengths/description/) - -- [Minimum Length of String After Deleting Similar Ends](https://leetcode.com/problems/minimum-length-of-string-after-deleting-similar-ends/description/) - -- [Determine if Two Strings Are Close](https://leetcode.com/problems/determine-if-two-strings-are-close/description/) - -- [Valid Parenthesis String](https://leetcode.com/problems/valid-parenthesis-string/description/) - -- [Longest Substring Without Repeating Characters](https://leetcode.com/problems/longest-substring-without-repeating-characters/description/) - -- [Remove K Digits](https://leetcode.com/problems/remove-k-digits/description/) \ No newline at end of file diff --git a/blog/2024-06-03-structure-probelms/structure-problems.md b/blog/2024-06-03-structure-probelms/structure-problems.md deleted file mode 100644 index 68ee62c19..000000000 --- a/blog/2024-06-03-structure-probelms/structure-problems.md +++ /dev/null @@ -1,15 +0,0 @@ ---- -slug: structure-problems -title: Structures and Pointers Problems -authors: [chaitanya] -tags: ["30daysofcpp", "struct", "pointer","practice-problems","hackerrank","geeksforgeeks","codechef"] ---- - -- [Cataloging Books](https://www.codechef.com/learn/course/college-oops-cpp/CPOPCPP05/problems/PPSCPP227) - -- [Student Details](https://www.hackerrank.com/challenges/c-tutorial-struct/problem) - -- [Structs and Objects](https://www.geeksforgeeks.org/problems/structs-and-objects/1) - -- [Pointer](https://www.hackerrank.com/challenges/c-tutorial-pointer/problem) - diff --git a/blog/2024-06-13-tree-problems/tree-problems.md b/blog/2024-06-13-tree-problems/tree-problems.md deleted file mode 100644 index 843dce82c..000000000 --- a/blog/2024-06-13-tree-problems/tree-problems.md +++ /dev/null @@ -1,36 +0,0 @@ ---- -slug: tree-problems -title: Trees Problems -authors: [khushi-kalra] -tags: ["30daysofcpp", "trees", "binaryTrees","practice-problems","leetcode"] ---- - -- [Invert Binary Tree](https://leetcode.com/problems/invert-binary-tree/description/) - -- [Maximum Depth of Binary Tree](https://leetcode.com/problems/maximum-depth-of-binary-tree/description/) - -- [Diameter of Binary Tree](https://leetcode.com/problems/diameter-of-binary-tree/description/) - -- [Balanced Binary Tree](https://leetcode.com/problems/balanced-binary-tree/description/) - -- [Same Tree](https://leetcode.com/problems/same-tree/description/) - -- [Subtree of Another Tree](https://leetcode.com/problems/subtree-of-another-tree/description/) - -- [Lowest Common Ancestor of a Binary Search Tree](https://leetcode.com/problems/lowest-common-ancestor-of-a-binary-search-tree/description/) - -- [Binary Tree Level Order Traversal](https://leetcode.com/problems/binary-tree-level-order-traversal/description/) - -- [Binary Tree Right Side View](https://leetcode.com/problems/binary-tree-right-side-view/description/) - -- [Count Good Nodes In Binary Tree](https://leetcode.com/problems/count-good-nodes-in-binary-tree/description/) - -- [Validate Binary Search Tree](https://leetcode.com/problems/validate-binary-search-tree/description/) - -- [Kth Smallest Element In a BST](https://leetcode.com/problems/kth-smallest-element-in-a-bst/description/) - -- [Construct Binary Tree From Preorder And Inorder Traversal](https://leetcode.com/problems/construct-binary-tree-from-preorder-and-inorder-traversal/description/) - -- [Binary Tree Maximum Path Sum](https://leetcode.com/problems/binary-tree-maximum-path-sum/description/) - -- [Serialize And Deserialize Binary Tree](https://leetcode.com/problems/serialize-and-deserialize-binary-tree/description/) \ No newline at end of file diff --git a/blog/2024-06-14-heap-problems/HEAP-problems.md b/blog/2024-06-14-heap-problems/HEAP-problems.md deleted file mode 100644 index 1a752df78..000000000 --- a/blog/2024-06-14-heap-problems/HEAP-problems.md +++ /dev/null @@ -1,29 +0,0 @@ ---- -slug: heap-problems -title: HEAP Problems -authors: [amruta] -tags: ["30daysofcpp", "heap", "techiedelight","practice-problems","codechef","hackerearth","geeksforgeeks","leetcode"] ---- - -- [Kth smallest element in an array](https://www.geeksforgeeks.org/kth-smallest-largest-element-in-unsorted-array/) - -- [Heap Sort](https://www.geeksforgeeks.org/problems/heap-sort/1) - -- [Merge `M` sorted lists of variable length](https://www.techiedelight.com/merge-m-sorted-lists-variable-length/) - -- [Minimum product of k integers](https://www.geeksforgeeks.org/minimum-product-k-integers-array-positive-integers/) - -- [Deletion in a Heap](https://www.codechef.com/practice/course/heaps/HEAPF/problems/HEAPEDU2) - -- [Insertion in a Heap](https://www.codechef.com/practice/course/heaps/HEAPF/problems/HEAPEDU1) - -- [Mode of an array](https://www.hackerearth.com/practice/data-structures/trees/heapspriority-queues/practice-problems/algorithm/making-more-e942ff93/) - -- [Find Median from Data Stream](https://leetcode.com/problems/find-median-from-data-stream/description/) - -- [The Skyline Problem](https://leetcode.com/problems/the-skyline-problem/description/) - -- [Sliding Window Maximum](https://leetcode.com/problems/sliding-window-maximum/description/) - -- [Strong Password Checker](https://leetcode.com/problems/strong-password-checker/description/) - diff --git a/blog/2024-06-14-pointers-problems/pointers-problem.md b/blog/2024-06-14-pointers-problems/pointers-problem.md deleted file mode 100644 index 198de170e..000000000 --- a/blog/2024-06-14-pointers-problems/pointers-problem.md +++ /dev/null @@ -1,31 +0,0 @@ ---- -slug: pointers-problems -title: Pointers Problems -authors: [Anshika] -tags: ["30daysofcpp", "pointers","practice-problems","leetcode","geeksforgeeks"] ---- - -- [Count Pairs Whose Sum is Less than Target](https://leetcode.com/problems/count-pairs-whose-sum-is-less-than-target/description/) - -- [Reverse Prefix of Word](https://leetcode.com/problems/reverse-prefix-of-word/description/) - -- [Partition Array According to Given Pivot](https://leetcode.com/problems/partition-array-according-to-given-pivot/description/) - -- [Flipping an Image](https://leetcode.com/problems/flipping-an-image/description/) - -- [Interval List Intersections](https://leetcode.com/problems/interval-list-intersections/description/) - -- [Sort Array By Parity II](https://leetcode.com/problems/sort-array-by-parity-ii/description/) - -- [Apply Operations to an Array](https://leetcode.com/problems/apply-operations-to-an-array/description/) - -- [ Divide Players Into Teams of Equal Skill](https://leetcode.com/problems/divide-players-into-teams-of-equal-skill/description/) - -- [Delete the Middle Node of a Linked List](https://leetcode.com/problems/delete-the-middle-node-of-a-linked-list/description/) -- [Move Zeroes](https://leetcode.com/problems/move-zeroes/description/) - -- [Count the triplets](https://www.geeksforgeeks.org/problems/count-the-triplets4615/1?page=1&category=two-pointer-algorithm&difficulty=Easy&sortBy=submissions) - -- [Intersection of two arrays](https://www.geeksforgeeks.org/problems/intersection-of-two-arrays2404/1?page=1&category=two-pointer-algorithm&difficulty=Easy&sortBy=submissions) - -- [Four Elements](https://www.geeksforgeeks.org/problems/four-elements2452/1?page=1&category=two-pointer-algorithm&difficulty=Easy&sortBy=submissions) diff --git a/blog/2024-06-14-recursion-problem/recursion-problem.md b/blog/2024-06-14-recursion-problem/recursion-problem.md deleted file mode 100644 index 72542bcbe..000000000 --- a/blog/2024-06-14-recursion-problem/recursion-problem.md +++ /dev/null @@ -1,27 +0,0 @@ ---- -slug: recursion-problems -title: Recursion Problems -authors: [Anshika] -tags: ["30daysofcpp", "recursion","practice-problems","leetcode","geeksforgeeks"] ---- - --[Fibonacci Number](https://leetcode.com/problems/fibonacci-number/description/) - -- [Reverse Linked List](https://leetcode.com/problems/reverse-linked-list/description/) - -- [Merge Two Sorted Lists](https://leetcode.com/problems/merge-two-sorted-lists/description/) - -- [Power of Four](https://leetcode.com/problems/power-of-four/description/) - -- [Power of Two](https://leetcode.com/problems/power-of-two/description/) - -- [Power of Three](https://leetcode.com/problems/power-of-three/description/) - -- [Print Pattern](https://www.geeksforgeeks.org/problems/print-pattern3549/1?page=1&category=Recursion&difficulty=Easy&sortBy=submissions) - -- [Recursive sequence](https://www.geeksforgeeks.org/problems/recursive-sequence1611/1?page=1&category=Recursion&difficulty=Easy&sortBy=submissions) - -- [Print N to 1 without loop](https://www.geeksforgeeks.org/problems/print-n-to-1-without-loop/1?page=1&category=Recursion&difficulty=Easy&sortBy=submissions) - -- [Divisor Game](https://www.geeksforgeeks.org/problems/divisor-game-1664432414/1?page=1&category=Recursion&difficulty=Easy&sortBy=submissions) - diff --git a/blog/2024-06-15-linked-list/linked-list-problems.md b/blog/2024-06-15-linked-list/linked-list-problems.md deleted file mode 100644 index 047986172..000000000 --- a/blog/2024-06-15-linked-list/linked-list-problems.md +++ /dev/null @@ -1,36 +0,0 @@ ---- -slug: linked-list-problems -title: Linked List Problems -authors: [Anshika] -tags: ["30daysofcpp", "arrays", "practice-problems","leetcode","geeksforgeeks"] ---- - -- [Remove Linked List Elements](https://leetcode.com/problems/remove-linked-list-elements/description/) - -- [Design HashMap](https://leetcode.com/problems/design-hashmap/description/) - -- [Intersection of Two Linked Lists](https://leetcode.com/problems/intersection-of-two-linked-lists/description/) - -- [Add Two Numbers](https://leetcode.com/problems/add-two-numbers/description/) - -- [Remove Nth Node From End of List](https://leetcode.com/problems/remove-nth-node-from-end-of-list/description/) - -- [Merge Two Sorted Lists](https://leetcode.com/problems/merge-two-sorted-lists/description/) - -- [Merge k Sorted Lists](https://leetcode.com/problems/merge-k-sorted-lists/description/) - -- [Swap Nodes in Pairs](https://leetcode.com/problems/swap-nodes-in-pairs/description/) - -- [Remove Duplicates from Sorted List](https://leetcode.com/problems/remove-duplicates-from-sorted-list/description/) - -- [Remove loop in Linked List](https://www.geeksforgeeks.org/problems/remove-loop-in-linked-list/1?page=1&category=Linked%20List&sortBy=submissions) - -- [Detect Loop in linked list](https://www.geeksforgeeks.org/problems/detect-loop-in-linked-list/1?page=1&category=Linked%20List&sortBy=submissions) - -- [Middle of a Linked List](https://www.geeksforgeeks.org/problems/finding-middle-element-in-a-linked-list/1?page=1&category=Linked%20List&sortBy=submissions) - -- [Rotate a Linked List](https://www.geeksforgeeks.org/problems/rotate-a-linked-list/1?page=1&category=Linked%20List&sortBy=submissions) - -- [Delete without head pointer](https://www.geeksforgeeks.org/problems/delete-without-head-pointer/1?page=1&category=Linked%20List&sortBy=submissions) - -- [Linked List Insertion](https://www.geeksforgeeks.org/problems/linked-list-insertion-1587115620/1?page=1&category=Linked%20List&sortBy=submissions) \ No newline at end of file diff --git a/blog/2024-06-17-LinkedList-problem/LinkedList-problems.md b/blog/2024-06-17-LinkedList-problem/LinkedList-problems.md deleted file mode 100644 index e0992c825..000000000 --- a/blog/2024-06-17-LinkedList-problem/LinkedList-problems.md +++ /dev/null @@ -1,16 +0,0 @@ ---- -slug: LinkedList-problems -title: LinkedList Problems -authors: [Braj] -tags: ["30daysofcpp", "linkedlist","practice-problems","leetcode","codeforces","geeksforgeeks","codechef","edabit"] ---- - -- [Find Middle of the Linked List](https://www.geeksforgeeks.org/write-a-c-function-to-print-the-middle-of-the-linked-list/) - -- [Reverse a Linked List](https://www.geeksforgeeks.org/reverse-a-linked-list/) - -- [Detect loop or cycle in a linked list](https://www.geeksforgeeks.org/detect-loop-in-a-linked-list/) - -- [Remove Nth Node from end of List](https://leetcode.com/problems/remove-nth-node-from-end-of-list/description/) - -- [Remove Duplicates from Sorted List](https://www.codechef.com/practice/course/linked-lists/LINKLISTF/problems/PREP55) \ No newline at end of file diff --git a/blog/authors.yml b/blog/authors.yml index 5c7a384bc..df2511348 100644 --- a/blog/authors.yml +++ b/blog/authors.yml @@ -22,3 +22,21 @@ khushikalra: url: https://github.com/abckhush image_url: https://yt3.googleusercontent.com/BpaBYEiGibr8uiNMCWytJ5BdKbPtpqTJAuA5Ida5rXAe8Zfvr8keZSPXYSqGasjGo7OunF2w=s176-c-k-c0x00ffffff-no-rj +Anshika: + name: Khushi Kalra + title: GSSoC'24 Contributor @30DaysOfCPP + url: https://github.com/abckhush + image_url: https://yt3.googleusercontent.com/BpaBYEiGibr8uiNMCWytJ5BdKbPtpqTJAuA5Ida5rXAe8Zfvr8keZSPXYSqGasjGo7OunF2w=s176-c-k-c0x00ffffff-no-rj + + +khushi-kalra: + name: Khushi Kalra + title: GSSoC'24 Contributor @30DaysOfCPP + url: https://github.com/abckhush + image_url: https://i.ibb.co/CP5hv84/user-1.png + +Braj: + name: Braj + title: GSSoC'24 Contributor @30DaysOfCPP + url: https://github.com/abckhush + image_url: https://i.ibb.co/CP5hv84/user-1.png diff --git a/blog/tags.yml b/blog/tags.yml new file mode 100644 index 000000000..ab8356058 --- /dev/null +++ b/blog/tags.yml @@ -0,0 +1,4 @@ +cpp: + label: C++ + permalink: /cpp + description: C Plus Plus Programming diff --git a/docs/Day 17/_category.json b/docs/Day 17/_category.json deleted file mode 100644 index c457f615c..000000000 --- a/docs/Day 17/_category.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 17", - "position": 17, - "link": { - "type": "generated-index" - } - } \ No newline at end of file diff --git a/docs/Day 17/exception-handling.md b/docs/Day 17/exception-handling.md deleted file mode 100644 index 38392acad..000000000 --- a/docs/Day 17/exception-handling.md +++ /dev/null @@ -1,177 +0,0 @@ ---- -sidebar_position: 1 -title: "Exception Handling in C++" -description: "Exception Handling provides a mechanism to handle unexpected situations (exceptions) that occur during the execution of a program, ensuring that the program can continue to operate or fail gracefully." -sidebar_label: "Exception Handling" -slug: exception-handling-in-cpp ---- - -# Exception Handling in C++ - -Exception handling in C++ is a powerful feature that allows developers to manage and respond to runtime errors in a controlled way. It provides a mechanism to handle unexpected situations (exceptions) that occur during the execution of a program, ensuring that the program can continue to operate or fail gracefully. - -It enables a program to deal with anomalies and unexpected conditions in a consistent and manageable way. It allows developers to separate error-handling code from regular code, improving readability and maintainability. - -## Basics of Exception Handling -The basic concept of exception handling involves three keywords: `try`, `throw`, and `catch`. - -1. **try:** The try block contains the code that may potentially throw an exception. -2. **throw:** The throw keyword is used to signal the occurrence of an anomaly or exceptional condition. -3. **catch:** The catch block handles the exception thrown by the throw statement. - -```cpp -#include <iostream> -using namespace std; - -int main() { - try { - // Code that may throw an exception - throw 20; - } - catch (int e) { - // Code that handles the exception - cout << "An exception occurred. Exception Nr. " << e << endl; - } - return 0; -} -``` - -## Exception Handling Mechanism - -The exception handling mechanism in C++ involves the following steps: -1. **Throwing an Exception:** When an error occurs, the program throws an exception using the throw keyword. -2. **Catching the Exception:** The thrown exception is caught by a catch block that matches the type of the exception. -3. **Handling the Exception:** The catch block contains code to handle the exception. - -### Throwing Exceptions -An exception can be thrown using the throw keyword followed by an exception object. This object can be of any type, including built-in types or user-defined types. - -```cpp -#include <iostream> -using namespace std; - -void test(int x) { - if (x == 0) { - throw "Division by zero condition!"; - } -} - -int main() { - try { - test(0); - } - catch (const char* msg) { - cout << "Caught: " << msg << endl; - } - return 0; -} -``` - -### Catching Exceptions -The catch block is used to handle exceptions. It must follow a try block. The parameter of the catch block determines the type of exception it can handle. - -```cpp -#include <iostream> -using namespace std; - -int main() { - try { - throw 100; - } - catch (int e) { - cout << "An exception occurred. Exception Nr. " << e << endl; - } - return 0; -} -``` - -### Multiple Catch Blocks -A single try block can have multiple catch blocks to handle different types of exceptions. - -```cpp -#include <iostream> -using namespace std; - -int main() { - try { - throw 100.5; - } - catch (int e) { - cout << "Caught an integer exception. Exception Nr. " << e << endl; - } - catch (double e) { - cout << "Caught a double exception. Exception Nr. " << e << endl; - } - return 0; -} -``` - -### Standard Exception Classes -C++ provides a set of standard exception classes defined in the `<stdexcept>` header file. Some of the commonly used standard exception classes are: - -1. `std::exception`: Base class for all standard exceptions. -2. `std::bad_alloc`: Thrown by new on allocation failure. -3. `std::bad_cast`: Thrown by dynamic_cast when it fails with a reference type. -4. `std::bad_typeid`: Thrown by typeid. -5. `std::logic_error`: Represents logic errors. -6. `std::runtime_error`: Represents runtime errors. - - -### User-Defined Exceptions -You can define your own exception classes by inheriting from the std::exception class or any of its derived classes. - -```cpp -#include <iostream> -#include <exception> -using namespace std; - -class MyException : public exception { - virtual const char* what() const throw() { - return "My custom exception occurred"; - } -}; - -int main() { - try { - throw MyException(); - } - catch (MyException& e) { - cout << e.what() << endl; - } - return 0; -} -``` - -### Stack Unwinding -When an exception is thrown, the stack unwinding process occurs. It means the destructor of each object is called for all objects constructed since the entry to the try block. - -```cpp -#include <iostream> -using namespace std; - -class Test { -public: - Test() { cout << "Constructor called" << endl; } - ~Test() { cout << "Destructor called" << endl; } -}; - -int main() { - try { - Test t; - throw 20; - } - catch (int e) { - cout << "Caught " << e << endl; - } - return 0; -} -``` - -## Best Practices -1. **Use Exceptions for Exceptional Conditions:** Exceptions should represent unexpected conditions, not regular control flow. -2. **Catch Specific Exceptions:** Catch specific exceptions to handle different error conditions appropriately. -3. **Resource Management:** Use RAII (Resource Acquisition Is Initialization) to manage resources, ensuring they are released even when exceptions occur. -4. **Minimize Exception Usage in Destructors:** Destructors should not throw exceptions to avoid unexpected behavior during stack unwinding. -5. **Document Exception Specifications:** Clearly document the exceptions that functions might throw. - -By understanding and effectively using exception handling in C++, you can write more robust and maintainable code, ensuring your programs can gracefully handle unexpected conditions and errors. \ No newline at end of file diff --git a/docs/Day 18/Doubly-Linked-list.md b/docs/Day 18/Doubly-Linked-list.md deleted file mode 100644 index 823b2308a..000000000 --- a/docs/Day 18/Doubly-Linked-list.md +++ /dev/null @@ -1,224 +0,0 @@ ---- -id: doubly-linked-list-cpp -title: Doubly Linked List in C++ -sidebar_label: Doubly Linked List in C++ -tags: -- Data Structures -- Linked List -- C++ -description: "A comprehensive guide to implementing and understanding doubly linked lists in C++." ---- - -## Doubly Linked List in C++ - -A doubly linked list is a type of linked list in which each node contains a data part and two pointers that reference the next and previous nodes in the sequence. This allows for traversal of the list in both directions. - -### Node Structure - -Each node in a doubly linked list contains three components: -1. **Data**: The value stored in the node. -2. **Next**: A pointer to the next node in the list. -3. **Prev**: A pointer to the previous node in the list. - -### Diagram - -Here is a visual representation of a doubly linked list: -``` -+------+ +------+ +------+ +------+ -| Prev |<--->| Prev |<--->| Prev |<--->| Prev | -| Data | | Data | | Data | | Data | -| Next |---> | Next |---> | Next |---> | Next | -+------+ +------+ +------+ +------+ -``` - -### Implementation - -Let's implement a doubly linked list in C++. - -#### Node Definition - -First, we define the structure of a node. - -```cpp -#include <iostream> - -struct Node { - int data; - Node* next; - Node* prev; - - Node(int val) : data(val), next(nullptr), prev(nullptr) {} -}; -``` -#### Doubly Linked List Class -Next, we define the class for the doubly linked list which includes methods for various operations like insertion, deletion, and traversal. - -```cpp -class DoublyLinkedList { -private: - Node* head; - -public: - DoublyLinkedList() : head(nullptr) {} - - // Insert at the beginning - void insertAtBeginning(int val) { - Node* newNode = new Node(val); - if (head != nullptr) { - head->prev = newNode; - } - newNode->next = head; - head = newNode; - } - - // Insert at the end - void insertAtEnd(int val) { - Node* newNode = new Node(val); - if (head == nullptr) { - head = newNode; - return; - } - Node* temp = head; - while (temp->next != nullptr) { - temp = temp->next; - } - temp->next = newNode; - newNode->prev = temp; - } - - // Delete a node - void deleteNode(int val) { - Node* temp = head; - while (temp != nullptr && temp->data != val) { - temp = temp->next; - } - if (temp == nullptr) return; // Node not found - - if (temp->prev != nullptr) { - temp->prev->next = temp->next; - } else { - head = temp->next; - } - if (temp->next != nullptr) { - temp->next->prev = temp->prev; - } - delete temp; - } - - // Display the list - void display() { - Node* temp = head; - while (temp != nullptr) { - std::cout << temp->data << " "; - temp = temp->next; - } - std::cout << std::endl; - } -}; -``` -### Operations - -#### Insertion at the Beginning -To insert a new node at the beginning of the list: - -1) Create a new node. -2) Set the new node's next pointer to the current head. -3) Set the current head's previous pointer to the new node. -4) Update the head to the new node. - -```cpp -void insertAtBeginning(int val) { - Node* newNode = new Node(val); - if (head != nullptr) { - head->prev = newNode; - } - newNode->next = head; - head = newNode; -} -``` -#### Insertion at the End -To insert a new node at the end of the list: - -1) Create a new node. -2) Traverse to the end of the list. -3) Set the last node's next pointer to the new node. -4) Set the new node's previous pointer to the last node. - -```cpp -void insertAtEnd(int val) { - Node* newNode = new Node(val); - if (head == nullptr) { - head = newNode; - return; - } - Node* temp = head; - while (temp->next != nullptr) { - temp = temp->next; - } - temp->next = newNode; - newNode->prev = temp; -} -``` -#### Deletion of a Node -To delete a node from the list: - -1) Traverse the list to find the node. -2) Update the previous node's next pointer to the node's next pointer. -3) Update the next node's previous pointer to the node's previous pointer. -4) Delete the node. - -```cpp -void deleteNode(int val) { - Node* temp = head; - while (temp != nullptr && temp->data != val) { - temp = temp->next; - } - if (temp == nullptr) return; // Node not found - - if (temp->prev != nullptr) { - temp->prev->next = temp->next; - } else { - head = temp->next; - } - if (temp->next != nullptr) { - temp->next->prev = temp->prev; - } - delete temp; -} -``` -#### Display the List -To display the list: - -1) Traverse from the head to the end of the list. -2) Print each node's data. - -```cpp -void display() { - Node* temp = head; - while (temp != nullptr) { - std::cout << temp->data << " "; - temp = temp->next; - } - std::cout << std::endl; -} -``` -### Example Usage - -```cpp -int main() { - DoublyLinkedList dll; - dll.insertAtBeginning(10); - dll.insertAtEnd(20); - dll.insertAtEnd(30); - dll.display(); // Output: 10 20 30 - dll.deleteNode(20); - dll.display(); // Output: 10 30 - return 0; -} -``` -### Conclusion -A doubly linked list is a versatile data structure that allows for efficient insertion and deletion of nodes from both ends. Understanding the implementation of a doubly linked list in C++ provides a solid foundation for working with more complex data structures. - -### References -- GeeksforGeeks: Doubly Linked List -- Wikipedia: Doubly Linked List \ No newline at end of file diff --git a/docs/Day 18/Stack-in-cpp.md b/docs/Day 18/Stack-in-cpp.md deleted file mode 100644 index 3d48e7651..000000000 --- a/docs/Day 18/Stack-in-cpp.md +++ /dev/null @@ -1,176 +0,0 @@ ---- -sidebar_position: 1 -title: "Stack in C++" -description: "In this tutorial, we will learn about Stack in C++ with the help of examples. Stack is a data structure which work on the principle of LIFO i.e Last-In-First-Out " -sidebar_label: "Stack" -slug: stack-in-cpp ---- - -# Stack in C++ -A Stack is a fundamental data structure in that follows the principle of Last-In-First-Out(LIFO). This means that the most recently added item is the first one to be removed. - -C++ has STL Library that provides built-in implementation of stack. -The stack template class in C++ STL provides an easy-to-use stack implementation. - -## Syntax of using Stack in C++ -```cpp -stack <type> St; -``` - -- Stack: it is name of stack template keyword we use to construct a stack object. -- type: it defines the data type of the element to be stored. -- St: it is the name of the stack object. - -## Header file for including Stack - -```cpp -#include <stack> -``` - -## Operations associated with a stack - -<b>1. Push </b>: Adds an element to the top of the stack. - -<b>2. Pop</b> : Removes the element at the top of the stack. - -<b>3. Peek(or Top)</b> : Returns the element at the top of stack without removing it. - -<b>4. IsEmpty</b> : Returns 1 if stack is empty else returns 0 if stack is not empty. - -<b>5. Size</b> : Returns the number of element in the stack. - -## Characteristics of a Stack - -- <b>LIFO Principle</b> : The last element added to the stack is the first element to be removed. -- <b>Order</b> : Elements are accessed in a sequential order determined by the operations(Push or Pop). -- <b>Implementation</b> : Can be implemented using arrays, linkedlist , or other data structures. - -## Example -```cpp -#include<iostream> -#include<stack> -using namespace std; -int main(){ - // creation - stack<int>st; - - // insertion - st.push(10); - st.push(20); - st.push(30); - // size check - cout<<"size of stack "<<st.size()<<endl; - - // remove/delete - st.pop(); - -// check empty -if(st.empty()){ - cout<<"empty stack"<<endl; -} -else{ - cout<<"not empty"<<endl; -} - -// top element -cout<<"top element: "<<st.top()<<endl; - } - -``` -### output -```cpp -Size of stack 3 -not empty -Top element 30 -``` - -## Applications of Stack - -- <b>Function Calls </b>: Used in the programming languages to store function call information. -- <b>Expression Evaluation</b> : Used in evaluating expressions , especially arithmetic expressions involving parentheses. -- <b>Backtracking</b> : Used in algorithm like Depth-First-Search(DFS) to store states for backtracking. - -## Implementation of Stack using Array - -Here's basic implementation program for stack using array - -```cpp -#include<iostream> -using namespace std; -class Stack{ - public: - int* arr; - int size; - int top; - Stack(int size){ - arr = new int(size); - this->size=size; - this->top=-1; - } - void push(int data){ - if(top==size-1){ - cout<<"overflow"<<endl; - } - else{ - top++; - arr[top]=data; - } - } - void pop(){ - if(top==-1){ - cout<<"underflow"<<endl; - }else{ - top--; - } - } - bool is_empty(){ - if(top==-1){ - return true; - } - else{ - return false; - } - } - int PeekElement(){ - if(top==-1){ - cout<<"stack is empty"<<endl; - return -1; - }else{ - return arr[top];} - } - int getsize(){ - return top+1; - } - void print(){ - cout<<"Stack: "; - for(int i=0;i<getsize();i++) - { - cout<<arr[i]<<" "; - } - } -}; -int main(){ - // creation - Stack st(8); - // pushing - st.push(50); - st.push(40); - st.push(30); - st.push(20); - st.push(10); - st.print(); - // removing - st.pop(); - // displaying - st.print(); - cout<<endl<<st.getsize(); - - return 0; -} -``` - -### Output -```cpp -Stack : 50 40 30 20 10 -Stack : 50 40 30 20 -Size : 4 \ No newline at end of file diff --git a/docs/Day 18/_category_.json b/docs/Day 18/_category_.json deleted file mode 100644 index 847f3c001..000000000 --- a/docs/Day 18/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 18", - "position": 18, - "link": { - "type": "generated-index" - } -} \ No newline at end of file diff --git a/docs/Practice_Question/Array/Battleships-in-a-Board.md b/docs/Practice_Question/Array/Battleships-in-a-Board.md deleted file mode 100644 index eb1545fd5..000000000 --- a/docs/Practice_Question/Array/Battleships-in-a-Board.md +++ /dev/null @@ -1,86 +0,0 @@ ---- -id: battleships-in-a-board -title: Battleships in a Board -sidebar_label: 0419-Battleships-in-a-Board -tags: -- Array -- Depth-First Search -- Matrix -description: "Given an `m x n` board where each cell is a battleship 'X' or empty '.', count the number of battleships on the board." ---- - -## Problem - -Given an `m x n` board where each cell is a battleship `'X'` or empty `'.'`, return the number of battleships on the board. - -Battleships can only be placed horizontally or vertically on the board. In other words, they can only occupy a contiguous line of cells horizontally or vertically. Each battleship must be separated by at least one empty cell (either horizontally or vertically) from any other battleship. - -### Examples - -**Example 1:** - -**Input:** `board = [["X",".",".","X"],[".",".",".","X"],[".",".",".","X"]]` -**Output:** `2` - -**Example 2:** - -**Input:** `board = [["."]]` -**Output:** `0` - -### Constraints - -- `m == board.length` -- `n == board[i].length` -- `1 <= m, n <= 200` -- `board[i][j]` is either `'X'` or `'.'`. - -### Follow-up - -Could you do it in one-pass, using only `O(1)` extra memory and without modifying the value of the board? - ---- - -## Approach - -To count the number of battleships in one pass and without extra memory, we can traverse the board and count only the top-left cell of each battleship. A cell qualifies as the top-left cell if there are no battleship cells above it or to the left of it. - -### Steps: - -1. Initialize a counter to keep track of the number of battleships. -2. Traverse each cell in the board. -3. For each cell, check if it is a battleship (`'X'`): - - If it is, check if there is no battleship cell above it and no battleship cell to the left of it. - - If both conditions are met, increment the battleship counter. -4. Return the counter after the traversal. - -### C++ Solution - -```cpp -class Solution { -public: - int countBattleships(vector<vector<char>>& board) { - int count = 0; - for (int i = 0; i < board.size(); i++) { - for (int j = 0; j < board[0].size(); j++) { - if (board[i][j] == 'X') { - if (i > 0 && board[i - 1][j] == 'X') continue; - if (j > 0 && board[i][j - 1] == 'X') continue; - count++; - } - } - } - return count; - } -}; -``` -### Complexity Analysis -**Time Complexity:** O(m * n) ->Reason: We traverse each cell of the board once. - -**Space Complexity:** O(1) ->Reason: We do not use any extra space that scales with the input size. - -### References -**LeetCode Problem:** Battleships in a Board - -**Solution Link:** Battleships in a Board Solution on LeetCode \ No newline at end of file diff --git a/docs/Practice_Question/String/Longest-Uncommon-Subsequence-II.md b/docs/Practice_Question/String/Longest-Uncommon-Subsequence-II.md deleted file mode 100644 index 493b369b4..000000000 --- a/docs/Practice_Question/String/Longest-Uncommon-Subsequence-II.md +++ /dev/null @@ -1,112 +0,0 @@ ---- -id: longest-uncommon-subsequence-ii -title: Longest Uncommon Subsequence II -sidebar_label: 0522-Longest-Uncommon-Subsequence-II -tags: -- String -- Sorting -description: "Given an array of strings strs, return the length of the longest uncommon subsequence between them. If the longest uncommon subsequence does not exist, return -1." ---- - -## Problem - -Given an array of strings `strs`, return the length of the longest uncommon subsequence between them. An uncommon subsequence is a subsequence that is not common to any other string in the array. - -A **subsequence** of a string `s` is a string that can be obtained after deleting any number of characters from `s`. - -### Examples - -**Example 1:** - -**Input:** `strs = ["aba","cdc","eae"]` -**Output:** `3` - -**Example 2:** - -**Input:** `strs = ["aaa","aaa","aa"]` -**Output:** `-1` - -### Constraints - -- `2 <= strs.length <= 50` -- `1 <= strs[i].length <= 10` -- `strs[i]` consists of lowercase English letters. - ---- - -## Approach - -To find the longest uncommon subsequence, we need to consider the following: - -1. If a string is unique in the list (i.e., it does not appear more than once), we need to check if it is not a subsequence of any other string. -2. If a string is not unique (i.e., it appears more than once), it cannot be an uncommon subsequence. -3. We can start by checking the strings in descending order of their lengths. This way, we can return the first string that meets the criteria as soon as we find it. - -### Steps: - -1. Sort the strings by length in descending order. -2. Check each string: - - If the string appears only once in the list. - - If it is not a subsequence of any other string longer than it. -3. If such a string is found, return its length. -4. If no such string is found, return `-1`. - -### Helper Function - -A helper function `is_subsequence` can be used to determine if one string is a subsequence of another. - -### C++ Solution -```cpp -#include <vector> -#include <string> -#include <algorithm> -using namespace std; - -class Solution { -public: - int findLUSlength(vector<string>& strs) { - sort(strs.begin(), strs.end(), [](const string &a, const string &b) { - return b.size() < a.size(); - }); - - for (int i = 0; i < strs.size(); i++) { - bool isSubsequence = false; - for (int j = 0; j < strs.size(); j++) { - if (i != j && isSubsequence(strs[i], strs[j])) { - isSubsequence = true; - break; - } - } - if (!isSubsequence) { - return strs[i].size(); - } - } - return -1; - } - -private: - bool isSubsequence(const string &a, const string &b) { - int i = 0, j = 0; - while (i < a.size() && j < b.size()) { - if (a[i] == b[j]) { - i++; - } - j++; - } - return i == a.size(); - } -}; -``` -### Complexity Analysis -**Time Complexity:** O(n^2 * l) ->Reason: Sorting the list takes O(n log n). Checking if a string is a subsequence of another string takes O(l) time, and this is done for each pair of strings, leading to O(n^2 * l) in total. - -**Space Complexity:** O(1) ->Reason: The space complexity is constant as we are not using any extra space proportional to the input size, other than the space required for sorting. - -### References -**LeetCode Problem:** Longest Uncommon Subsequence II - -**Solution Link:** LeetCode Solution - -**Wikipedia:** Subsequence \ No newline at end of file diff --git a/docs/Practice_Question/Tree/Convert-BST-to-Greater-Tree.md b/docs/Practice_Question/Tree/Convert-BST-to-Greater-Tree.md deleted file mode 100644 index 3c6cfbb1e..000000000 --- a/docs/Practice_Question/Tree/Convert-BST-to-Greater-Tree.md +++ /dev/null @@ -1,89 +0,0 @@ ---- -id: convert-bst-to-greater-tree -title: Convert BST to Greater Tree -sidebar_label: 0538-Convert-BST-to-Greater-Tree -tags: -- Tree -- Depth-First Search -- Binary Search Tree -- Binary Tree -description: "Given the root of a Binary Search Tree (BST), convert it to a Greater Tree such that every key of the original BST is changed to the original key plus the sum of all keys greater than the original key in BST." ---- - -## Problem - -Given the root of a Binary Search Tree (BST), convert it to a Greater Tree such that every key of the original BST is changed to the original key plus the sum of all keys greater than the original key in BST. - -### Examples - -**Example 1:** - -**Input:** `root = [4,1,6,0,2,5,7,null,null,null,3,null,null,null,8]` -**Output:** `[30,36,21,36,35,26,15,null,null,null,33,null,null,null,8]` - -**Example 2:** - -**Input:** `root = [0,null,1]` -**Output:** `[1,null,1]` - -### Constraints - -- The number of nodes in the tree is in the range `[0, 10^4]`. -- `-10^4 <= Node.val <= 10^4` -- All the values in the tree are unique. -- `root` is guaranteed to be a valid binary search tree. - ---- - -## Approach - -To convert a BST to a Greater Tree, we need to accumulate the sum of all nodes that are greater than the current node. This can be efficiently done using a reverse in-order traversal (right-root-left), which processes nodes from the largest to the smallest. - -### Steps: - -1. Initialize a variable to keep track of the running sum. -2. Perform a reverse in-order traversal of the tree. -3. During the traversal, update the value of each node to include the running sum. -4. Update the running sum with the value of the current node. - -### C++ Solution - -```cpp -#include <iostream> -using namespace std; - -struct TreeNode { - int val; - TreeNode *left; - TreeNode *right; - TreeNode(int x) : val(x), left(NULL), right(NULL) {} -}; - -class Solution { -private: - int sum = 0; -public: - TreeNode* convertBST(TreeNode* root) { - if (root != nullptr) { - convertBST(root->right); - sum += root->val; - root->val = sum; - convertBST(root->left); - } - return root; - } -}; -``` -### Complexity Analysis -**Time Complexity:** O(n) ->Reason: Each node is visited once during the traversal. - -**Space Complexity:** O(h) ->Reason: The space complexity is determined by the recursion stack, which in the worst case (unbalanced tree) is O(n), but on average (balanced tree) is O(log n). - -### References -**LeetCode Problem:** Convert BST to Greater Tree - -**Solution Link:** LeetCode Solution - -**Wikipedia:** Binary Search Tree \ No newline at end of file diff --git a/docs/day-02/_category_.json b/docs/day-02/_category_.json deleted file mode 100644 index 7ced805b4..000000000 --- a/docs/day-02/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 02", - "position": 3, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-02/comments-in-cpp.md b/docs/day-02/comments-in-cpp.md deleted file mode 100644 index 3f4aab9ae..000000000 --- a/docs/day-02/comments-in-cpp.md +++ /dev/null @@ -1,77 +0,0 @@ ---- -sidebar_position: 2 -title: "Comment in C++" -description: "This is a simple program to demonstrate the use of comments in C Plus Plus." -sidebar_label: "Comment" -slug: comment-in-cpp ---- - - - -## 1. What is Comment in C++? -- A comment in C++ is a programmer-readable note that is inserted directly into the source code of a program. -- Comments are ignored by the compiler and are meant for the programmer’s use only. -- They serve as a form of in-code documentation, helping developers understand the purpose, logic, or explanation behind specific code lines - -## 2. Why do we use comments in C++? -Comments serve several purposes: -- Explanation: They explain the code, making it more readable and understandable for other programmers. -- Debugging: Comments can be useful for debugging by providing context or temporarily disabling code segments. -- Documentation: They document algorithms, variable purposes, or clarify unclear code segments. -- Collaboration: Comments help other developers understand your code when collaborating on projects. - -![comment-in-cpp](../../static/img/day-02/comment-in-cpp.png) - -## 3. Write a simple program to demonstrate the use of comments in C++. -```cpp -#include <iostream> -using namespace std; - -int main() { - // This is a single-line comment - cout << "Hello, World!"; // Another single-line comment - return 0; -} -``` -In this program, we use both single-line comments (//) to explain the code and prevent execution of those comment lines - -## 4. Types of comments in C++ - i. Single Line Comment -- Starts with // and applies to a single line only. -- Compiler ignores any text after //. -- Used for brief explanations or annotations within a line of code. -Example: -``` cpp -int age = 25; // Stores the user's age - -``` - ii. Multi Line Comment -- Starts with /* and ends with */. -- Can span multiple lines but cannot be nested. -- Any text between /* and */ is ignored by the compiler. -- Used for longer descriptions, explaining complex logic or function purposes. -Example: -```cpp -/* -* This function calculates the area of a rectangle -* given its length and width. -*/ -int calculateArea(int length, int width) { - // ... function implementation -} - - ``` - iii. Documentation Comment -- Used for documenting functions, classes, and their parameters. -- Typically starts with /** and ends with */. -- Contains additional information for tools like Doxygen. -- Example (not standard C++): -```cpp -/** - * @param x integer value to add - * @param y integer value to add - @@ -66,3 +75,4 @@ int add(int x, int y) { -} -``` - -By effectively using comments, you can improve the understandability and maintainability of your C++ programs, both for yourself and others who may read your code in the future. \ No newline at end of file diff --git a/docs/day-02/first-cpp-program.md b/docs/day-02/first-cpp-program.md deleted file mode 100644 index a176d8db9..000000000 --- a/docs/day-02/first-cpp-program.md +++ /dev/null @@ -1,110 +0,0 @@ ---- -sidebar_position: 1 -title: "First C++ Program: Hello, World!" -description: "Learn how to write and execute your first C++ program with a simple 'Hello, World!' example." -sidebar_label: "First C++ Program" -slug: first-cpp-program ---- - -## Your First Steps in C++: Hello, World! - -Welcome to the exciting world of C++ programming! Today, we'll embark on a journey together, crafting our very first C++ program - the classic "Hello, World!". This simple program lays the foundation for understanding core C++ concepts. - -### Setting Up - -Before diving into code, you'll need a text editor or an Integrated Development Environment (IDE) to write and compile your C++ program. Popular choices include Notepad++, Visual Studio Code, or Code::Blocks. - -![first-programme-in-cpp](../../static/img/day-02/first-program.png) - -### Write a Simple "Hello, World!" Program in C++ - -``` -#include <iostream> - -int main() { - std::cout << "Hello, World!" << std::endl; - return 0; -} - -``` -### 2. Output of the program. -When you run this program, it will display the following output: -``` -Hello, World! -``` -You'll need a C++ compiler to run this program. Here's a general process: - -- Save the code in a file with a `.cpp` extension (e.g., `hello_world.cpp`). -- Compile the code using a C++ compiler. The specific command will vary depending on your compiler. -- Execute the compiled program (the generated executable file). - -![first-programme-in-cpp](../../static/img/day-02/first-program.png) - -### 3. Explain the code line by line. - -1. `#include <iostream>`: This line is called a preprocessor directive. It instructs the compiler to include the contents of the `<iostream> `header file. This header file provides essential input/output functionalities like cout for printing to the console. - - -2. `int main()`: This line declares the main function, which is the program's entry point. The int keyword specifies that the main function will return an integer value (usually 0 to indicate successful execution). - - -3. { }: The curly braces mark the beginning and end of the code block for the main function. All the statements within this block will be executed when the program runs. - -4. std::cout > > "Hello, World!" > > std::endl;: This line is the heart of the program. It performs the following actions: - - - std::cout: This is an object of the ostream class (from >iostream<) used for standard output (printing to the console). - - > >: This is the stream insertion operator. It's used to send data to the output stream (cout) on the left side. - - "Hello, World!": This is the actual string literal that you want to print. - - std::endl: This manipulator inserts a newline character after the string, ensuring the output appears on a new line. -5. return 0; : This line exits the main function and returns the value 0 to the operating system. A return value of 0 typically indicates successful program execution. - -### 4. Explain Basic Structure of C++ Program. -1. Preprocessor Directives (Optional): - -- Lines starting with `#`. -- Not actual C++ statements but instructions for the preprocessor (a separate program that runs before compilation). -- Common example: `#include <iostream>` - This includes the `iostream` header file, providing input/output functionalities like cout for printing to the console. -2. Namespaces (Optional): - -- Lines using the `namespace` keyword. -- Help organize code by grouping related elements (like functions, classes) under a specific namespace. -- Common example: `using namespace std;` - This brings the std namespace (containing standard objects like `cout`) into scope, avoiding repetitive use of `std::`. -3. Function Definitions: - -- Functions are reusable blocks of code that perform specific tasks. -- Defined using a return type, name, parameter list (optional), and a code block within curly braces `({})`. -- The `main` function is the entry point of the program, where execution begins. -4. Variable Declarations: - -Variables store data during program execution. -Declared using a data type (e.g., `int`, `double`) and a name following specific naming rules (letters, numbers, underscores, case-sensitive). -Example: `int age = 25;` - Declares an integer variable `age` and initializes it with the value 25. -5. Statements: - -Lines that perform actions or control the program flow. -Examples: - - `cout << "Hello, World!" << endl;` - Prints "Hello, World!" to the console. - - `if (age >= 18) { ... }` - Conditional statement to check if age is greater than or equal to 18 and execute code within the block if true. - - `for (int i = 0; i < 3; i++) { ... }` - Loop that iterates three times. -6. Comments (Optional): - -- Lines starting with `//` (single line comment) or `/* ... */` (multi-line comment). -- Provide explanations within the code for better understanding. -- Ignored by the compiler but essential for human-readable code. -Here's a basic program structure summarizing these elements: -``` -C++ -#include <iostream> // Preprocessor directive (optional) - -using namespace std; // Namespaces (optional) - -// Function definitions -int main() { - // Variable declarations and statements - cout << "Hello, World!" << endl; - return 0; -} -``` - - -Remember, this is a basic structure, and more complex programs may involve additional elements like classes, objects, and header files for custom functions. \ No newline at end of file diff --git a/docs/day-02/keywords-identifiers.md b/docs/day-02/keywords-identifiers.md deleted file mode 100644 index c9955b4df..000000000 --- a/docs/day-02/keywords-identifiers.md +++ /dev/null @@ -1,123 +0,0 @@ ---- -sidebar_position: 3 -title: "Keywords and Identifiers in C++" -description: "Keywords and Identifiers in C++. This is a simple program to demonstrate the use of keywords and identifiers in C Plus Plus." -sidebar_label: "Keywords and Identifiers" -slug: keywords-and-identifiers-in-cpp ---- - - -### 1. What is Keywords and Identifiers in C++? - -## Keywords: -- Keywords are predefined words that have special meanings to the C++ compiler. -- They are part of the language syntax and serve specific purposes. -- They are always written in lowercase in C++. -- It have a fixed set(around 32 in C++)that doesn't change. -- For example, int, if, while, and class are keywords. -- Keywords cannot be used as identifiers (variable names, function names, etc.) because they already have predefined meanings. -## Identifiers: -- Identifiers are unique names given to variables, functions, classes, and other entities by the programmer. -- They help us create meaningful and descriptive names for program elements. -- Examples of identifiers: money, accountBalance, studentAge, and calculateSum. -- Must follow the below specific naming rules: - -### Rules for naming identifiers: -- Can consist of letters (A-Z or a-z), digits (0-9), and underscores (_). -- Must begin with a letter or an underscore. -- Are case-sensitive (e.g., Num and num are different). -- Cannot use reserved keywords as identifiers. -- Must be unique within their namespace (e.g., no two variables with the same name in the same scope)31. -### 2. Why do we use Keywords and Identifiers in C++? -#### we use keywords: -- Syntax: Keywords define the syntax and structure of the language. They help the compiler understand the code. -- Reserved Meanings: Each keyword has a reserved purpose (e.g., if for conditional statements, while for loops, class for defining classes). -- Consistency: Using keywords ensures consistency across different C++ programs. -- Efficiency: Keywords allow the compiler to optimize code execution. -- Readability: They make the code more readable and self-explanatory. -#### we use identifiers: -- Descriptive Names: Identifiers give meaningful names to program entities (e.g., totalAmount, calculateAverage). -- Readability: Well-chosen identifiers enhance code readability for both programmers and collaborators. -- Avoid Magic Numbers: Instead of using raw numbers (e.g., 42), we use identifiers (e.g., MAX_SCORE) to make the code self-documenting. -- Modularity: Identifiers help organize code into logical units (functions, classes, etc.). -- Avoid Confusion: Descriptive identifiers prevent confusion and improve maintainability. -### 3. Write a simple program to demonstrate the use of Keywords and Identifiers in C++. -```cpp -#include <iostream> - -using namespace std; - -int main() { - // Integer variable to store age (identifier) - int age = 25; - - // `if` is a keyword for conditional statement - if (age >= 18) { - cout << "You are eligible to vote." << endl; - } - - // `for` is a keyword for loop - for (int i = 0; i < 3; i++) { - cout << "Iteration: " << i << endl; - } - - // `double` is a keyword for floating-point numbers (identifier) - double pi = 3.14159; - cout << "Value of pi: " << pi << endl; - - // `calculateArea` is a user-defined identifier (function name) - int area = calculateArea(5, 4); // Assuming calculateArea is defined elsewhere - cout << "Area of rectangle: " << area << endl; - - return 0; -} - -// This function (identifier) is not defined here, but for demonstration purposes -int calculateArea(int length, int width) { - return length * width; -} -``` -![keywords-and-identifiers-in-cpp](../../static/img/day-02/keywords-in-cpp.png) -### 4. List of Keywords in C++ -C++ has a set of around 32 keywords that have special meanings within the language. Here's a list for your reference: -- Basic data types: int, float, double, char, bool -- Storage specifiers: auto, register, static, extern -- Type specifiers: void, const, volatile -- Control flow: if, else, for, while, do, switch, case, break, continue, return -- Function definitions: inline, friend, virtual -- Object-oriented programming: class, struct, public, private, protected, this, new, delete -- Exception handling: try, catch, throw -- Other: sizeof, namespace, template, typedef -``Note``: This is not an exhaustive list, and the exact number of keywords may vary slightly depending on the C++ version you're using. It's always a good practice to refer to the official C++ documentation for the latest keyword definitions. -### 5. Rules for defining Identifiers in C++ -Remember these rules when defining identifiers: -- Must start with a letter or underscore. Cannot start with a digit. -- Consist of letters, digits, and underscores. -- Avoid using reserved keywords as identifiers. -- Be case-sensitive (e.g., myVar and MyVar are different). -- No limit on the length of an identifier. -- Cannot be the same as keywords in C++. -### 6. Examples of Identifiers in C++ -#### Valid Identifiers: - - Starts with letter or underscore - `age`, `_temporary`, `myObject` - - Can contain letters, digits, and underscores - `calculate_area`, `x123` - - Case-sensitive - `age`, `Age` - - Cannot be a keyword - `cpp_keyword` (not recommended) -#### Invalid Identifiers: -- Starts with a number - `1st_place` -- Contains hyphen - `my-function` -- Keywords - `int`,`while` -### 7. Difference between Keywords and Identifiers in C++ -- Keywords are predefined words with specific meanings in the language , while identifiers are user-defined names for program elements. -- Keyword can control flow and structure but Identifiers, identify program elements. -- Keywords cannot be used as identifiers.On the other hand, identifiers used for variables , functions , classes , etc. -- Keywords have fixed set, lowercase only but , identifiers defined by programmer , case sensitive. -- Examples of keyword: `int`,`if`,`while`,`class`. -- Examples of identifier: `age`,`calculateArea`,`myObject`. \ No newline at end of file diff --git a/docs/day-02/new-line-in-cpp.md b/docs/day-02/new-line-in-cpp.md deleted file mode 100644 index cb08eda31..000000000 --- a/docs/day-02/new-line-in-cpp.md +++ /dev/null @@ -1,71 +0,0 @@ ---- -sidebar_position: 4 -title: "Adding New Line in C++" -description: "Explore various methods to add new line in C++ with illustrative examples." -sidebar_label: "New Line in C++" -slug: adding-new-line-in-cpp ---- - - -# Adding New Line in C++ -There are two common ways to add a new line in C++: using `"\n"` and `"std::endl"`. - -## Using `"\n"`: -The `"\n"` escape sequence is a simple way to add a new line in C++. It instructs the program to start printing from the next line. - -#### Example: -```cpp -#include <iostream> -using namespace std; - -int main() { - cout << "Hello\n"; // Using newline character (\n) - cout << "World\n"; - return 0; -} -``` - -**Output**: -```cpp -Hello -World -``` - - -## Using `"std::endl"`: -`std::endl` is a manipulator in the C++ standard library that not only adds a new - line but also flushes the output buffer, ensuring immediate display. - -#### Example: -```cpp -#include <iostream> -using namespace std; - -int main() { - cout << "Hello" << endl; // Using std::endl - cout << "World" << endl; - return 0; -} - -``` -**Output**: -```cpp -Hello -World -``` - - -## Comparison of `\n` and `endl`: -Both `"\n"` and `std::endl` produce the same output, but there are differences in their usage and performance. - -#### Performance : -In terms of performance, `\n` is generally faster than `std::endl`. -`std::endl` flushes the output buffer, which may impact performance, especially for large outputs. On the other hand, `\n` does not flush the buffer immediately, making it more efficient. - -#### Usage: - -- Use `std::endl` when you need immediate display of the output or when you want to ensure that certain messages are visible right away, such as in interactive programs or debugging scenarios. -- Use `\n` in most cases where immediate flushing isn't necessary for better performance. - -Understanding the differences between `std::endl` and `\n` helps in choosing the appropriate method based on the requirements of your program. - -Feel free to use either method based on your specific needs! \ No newline at end of file diff --git a/docs/day-03/_category_.json b/docs/day-03/_category_.json deleted file mode 100644 index 91740c50d..000000000 --- a/docs/day-03/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 03", - "position": 4, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-03/cpp-type-modifiers.md b/docs/day-03/cpp-type-modifiers.md deleted file mode 100644 index e73bae422..000000000 --- a/docs/day-03/cpp-type-modifiers.md +++ /dev/null @@ -1,95 +0,0 @@ ---- -sidebar_position: 3 -title: "Type Modifiers in C++" -description: "Type modifiers are used to change the meaning of the fundamental data types. In this tutorial, we will learn about type-modifiers and how to use them in C++ programming with the help of examples." -sidebar_label: "Type Modifiers" -slug: type-modifiers-in-cpp ---- - - -### 1. What is Type Modifiers in C++? -Type modifiers in C++ are keywords that you use to alter the meaning of the basic data types to fit specific needs of your program. They allow you to specify more precisely the properties of variables, such as their size and whether they can hold negative values. The primary type modifiers in C++ are `short`, `long`, `signed`, and `unsigned`. - - -### 2. Types of Type Modifiers in C++ with Proper Examples. -#### Types of Type Modifiers in C++: -- `short` -- `long` -- `signed` -- `unsigned` -- `long long` -- `short int` -- `long int` -- `long double` - -![Type Modifiers in CPP](../../static/img/day-03/type-modifiers-in-cpp.png) - -### 3. short type Modifier -The `short` modifier reduces the size of the `int` data type. Typically, a `short int` is at least 16 bits. -```cpp -short a; // Declares a short integer variable -short int b; // Equivalent to short a -``` -### 4. long type Modifier -The `long` modifier increases the size of the `int` data type. Typically, a `long int` is at least 32 bits. - -Example: - -```cpp -long a; // Declares a long integer variable -long int b; // Equivalent to long a -``` -### 5. signed type Modifier -The `signed` modifier allows a data type to store both positive and negative values. By default, integer types are `signed`. - -Example: - -```cpp - -signed int a; // Explicitly declares a signed integer variable -signed char b; // Declares a signed character variable -``` -### 6. unsigned type Modifier -- These modifiers can be used with `int` and `char` data types. -- `Signed` variables can hold both positive and negative integers, including zero. -- By default, integers are `signed`, so we can directly use `int`. -- `unsigned` variables can hold only non-negative integer values. -Example: -```cpp -signed int x = 23; // Positive-valued integer -signed int y = -13; // Negative-valued integer -unsigned int u = 2; // Positive-valued integer -``` -### 7. long long type Modifier -- The `long long` type modifier can be repeated twice to create the `long long` type. -- It is used for even larger numbers than `long`. -- This modifier can only be used with `int`. -Example: -```cpp -long long num = 12345678; // Very large integer -``` -### 8. short int type Modifier -- The `short int` type modifier is used to create a smaller integer variable that occupies less memory than a regular `int`. -- It restricts the range of values that can be stored in the variable. -- A `short int` typically uses two bytes of memory. -Example: -```cpp -short int smallNumber = 12345; -``` -### 9. long int type Modifier -- The `long int` type modifier is used to create an integer variable that can store larger values than a regular `int`. -- It extends the range of values that an int can hold. -- A `long int` typically uses four bytes of memory (32 bits). -- The range of a long int is -2,147,483,648 to 2,147,483,647. -- The format specifier for `long int` is `%ld`. -Example: -```cpp -long int largeNumber = 1234567890; -``` -### 10. long double type Modifier -The `long double` modifier is used for large floating-point numbers. -Example: -```cpp -long double c = 0.333333333333333333L; // Large floating-point number -``` - diff --git a/docs/day-03/datatypes-in-cpp.md b/docs/day-03/datatypes-in-cpp.md deleted file mode 100644 index f3438a94d..000000000 --- a/docs/day-03/datatypes-in-cpp.md +++ /dev/null @@ -1,132 +0,0 @@ ---- -sidebar_position: 2 -title: "Data Types in C++" -description: "In this tutorial, we will learn about basic data types such as int, float, char, etc. in C++ programming with the help of examples. A data type determines the type and size of an variable." -sidebar_label: "Datatypes" -slug: data-types-in-cpp ---- - -### 1. What is Data Types in C++? -All variables use data type during declaration to restrict the type of data to be stored. Therefore, we can say that data types are used to tell the variables the type of data they can store. Whenever a variable is defined in C++, the compiler allocates some memory for that variable based on the data type with which it is declared. Every data type requires a different amount of memory. -#### C++ supports the following data types: - -1. Primary or Built-in or Fundamental data type -2. Derived data types -3. User-defined data types - -![Type Modifiers in CPP](../../static/img/day-03/datatypes-in-cpp.png) - -### 2. C++ Fundamental Data Types - These data types are built-in or predefined data types and can be used directly by the user to declare variables. example: int, char, float, bool, etc. Fundamental data types available in C++ are: - -- Integer -- Character -- Boolean -- Floating Point -- Double Floating Point -- Valueless or Void -- Wide Character -### 3. Examples of Data Types in C++ -- Integer: The keyword used for integer data types is ``int``. Integers typically require 4 bytes of memory space and range from -2147483648 to 2147483647. -- Character: Character data type is used for storing characters. The keyword used for the character data type is ``char``. Characters typically require 1 byte of memory space and range from -128 to 127 or 0 to 255. -- Boolean: Boolean data type is used for storing Boolean or logical values. A Boolean variable can store either `true` or `false`. The keyword used for the Boolean data type is ``bool``. -- Floating Point: Floating Point data type is used for storing single-precision floating-point values or decimal values. The keyword used for the floating-point data type is ``float``. Float variables typically require 4 bytes of memory space. -- Double Floating Point: Double Floating Point data type is used for storing double-precision floating-point values or decimal values. The keyword used for the double floating-point data type is ``double``. Double variables typically require 8 bytes of memory space. -- void: Void means without any value. void data type represents a valueless entity. A ``void`` data type is used for those function which does not return a value. -- Wide Character: Wide character data type is also a character data type but this data type has a size greater than the normal 8-bit data type. Represented by ``wchar_t``. It is generally 2 or 4 bytes long. -- sizeof() operator: ``sizeof()`` operator is used to find the number of bytes occupied by a variable/data type in computer memory. -### 4. C++ Modified Data Types List -1. Enumerations (enum): -Enumerations allow you to define a set of named integer constants. -```cpp -Example: - -enum Color { RED, GREEN, BLUE }; -``` - -2. Structures (struct): -Structures allow you to group related variables of different data types into a single unit. -```cpp -Example: - -struct Point { - int x; - int y; -}; -``` - -3. Unions (union): -Unions allow you to store different data types in the same memory location. -Only one member of the union can be accessed at a time. -```cpp -Example: - -union Data { - int i; - float f; - char c; -}; -``` - -4. Classes (class): -Classes are used for object-oriented programming. -They encapsulate data (attributes) and methods (functions) into a single unit. -```cpp -Example: - -class Circle { - double radius; -public: - double getArea() { return 3.14 * radius * radius; } -}; -``` - -5. Arrays: -Arrays allow you to store multiple elements of the same data type in a contiguous memory block. -```cpp -Example: - -int scores[5] = { 90, 85, 78, 92, 88 }; -``` -### 5. Derived Data Types in C++ - Derived data types that are derived from the primitive or built-in datatypes are referred to as Derived Data Types. These can be of four types namely: - -1. Function: -A function is a block of code or program segment that performs a specific well-defined task. -Functions allow you to encapsulate a set of instructions and reuse them. -```cpp -Example: - -int max(int x, int y) { - return (x > y) ? x : y; -} -``` - -2. Array: -An array is a collection of elements of the same data type stored in contiguous memory locations. -It allows you to represent many instances of a value in a single variable. -```cpp -Example: - -int scores[5] = { 90, 85, 78, 92, 88 }; -``` - -3. Pointers: -Pointers are symbolic representations of memory addresses. -They allow programs to simulate call-by-reference and create dynamic data structures. -```cpp -Example: - -int num = 42; -int* ptr = # -``` - -4. References: -References provide an alias for an existing variable. -They allow you to work with the original variable directly. -```cpp -Example: - -int original = 100; -int& ref = original; -``` diff --git a/docs/day-03/variables-literals-constant-in-cpp.md b/docs/day-03/variables-literals-constant-in-cpp.md deleted file mode 100644 index 7f6c0a74a..000000000 --- a/docs/day-03/variables-literals-constant-in-cpp.md +++ /dev/null @@ -1,224 +0,0 @@ ---- -sidebar_position: 1 -title: "Variables, Literals, and Constants in C++" -description: "This is a simple program to demonstrate the use of variables, literals, and constants in C Plus Plus." -sidebar_label: "Variables, Literals, and Constants" -slug: variables-literals-constant-in-cpp ---- - - - -### 1. What is Variables, Literals, and Constants in C++? -#### Variables -- A variable is a container (storage area) used to hold data. -- Each variable is given a unique name (identifier) to indicate its storage area. -```cpp -For example: -int age = 14; // 'age' is a variable of the int data type -age = 17; // Now 'age' is 17 -``` -- Variables allow us to store and manipulate data during program execution. -#### Constants: -- A constant is a value that cannot be changed once it has been defined. -- Constants are treated like regular variables, but their values remain fixed. -- We use the const keyword to declare constants. -```cpp -Example: -const int LIGHT_SPEED = 299792458; // LIGHT_SPEED is a constant -// Attempting to change LIGHT_SPEED will result in an error -``` - -- Constants ensure that specific, unchanging values are used throughout the program. -#### Literals: -- Literals are fixed values used directly in the code. -- They represent specific data without any variables or calculations. -```cpp -Examples of literals: -Integer literals: 9, 42, -5 -Floating-point literals: 3.14, -0.005 -Character literals: 'A', 'b', '1' -String literals: "Hello, World!", "C++ is fun" -``` -- Literals cannot be assigned different values; they remain constant. -### 2. Why do we use Variables, Literals, and Constants in C++? -1. Variables: -- Allow us to store and manipulate data dynamically during program execution. -- Enable flexibility and adaptability in our code. -- Improve readability by giving meaningful names to data. -2. Constants: -- Ensure specific values remain fixed throughout the program. -- Enhance code clarity by using descriptive names for important values. -- Prevent accidental modification of critical data. -3. Literals: -- Provide fixed values directly in the code. -- Improve code readability by eliminating magic numbers. -- Represent specific data without the need for variables. -### 3. Write a simple program to demonstrate the use of Variables, Literals, and Constants in C++. -```c++ -#include <iostream> -using namespace std; - -int main() { - // Variables - int age = 25; - double pi = 3.14; - char grade = 'A'; - - // Constants - const int LIGHT_SPEED = 299792458; - - // Literals - int num1 = 42; // Integer literal - double num2 = 2.71828; // Floating-point literal - char letter = 'X'; // Character literal - string message = "Hello, World!"; // String literal - - // Display values - cout << "Age: " << age << endl; - cout << "Pi: " << pi << endl; - cout << "Grade: " << grade << endl; - cout << "Speed of light: " << LIGHT_SPEED << " m/s" << endl; - cout << "Integer literal: " << num1 << endl; - cout << "Floating-point literal: " << num2 << endl; - cout << "Character literal: " << letter << endl; - cout << "String literal: " << message << endl; - - return 0; -} -``` -![variables in c++](../../static/img/day-03/variables-literals-constarts-in-cpp.png) - -### 4. Types of Variables in C++ -i. Local Variables: -- Local variables are declared within a function or a block of code. -- They have local scope, meaning they are accessible only within the function or block where they are defined. -- Local variables are created when the function or block is entered and destroyed when it exits. -```c++ -Example: -void myFunction() { - int localVar = 42; // Local variable - // ... -} -``` -ii. Global Variables: -- Global variables are declared outside any function or block. -- They have global scope, meaning they can be accessed from any part of the program. -- Global variables exist throughout the program’s execution. -```c++ -Example: -int globalVar = 100; // Global variable - -void myFunction() { - // Access globalVar here - // ... -} -``` -iii. Static Variables: -- Static variables are local variables with a special property. -- They retain their value between function calls. -- Static variables are initialized only once, even if the function is called multiple times. -```c++ -Example: -void myFunction() { - static int count = 0; // Static variable - count++; - // ... -} -``` - -iv. Register Variables: -- Register variables are used to request the compiler to store the variable in a CPU register for faster access. -- The register keyword hints the compiler to optimize access to this variable. -- Note that the compiler may ignore the request if it deems it unnecessary. -```c++ -Example: -register int speed = 100; // Register variable -``` -### 5. Types of Literals in C++ -Literals are the constant values that are assigned to the variables. Literals represent fixed values that cannot be modified. Literals contain memory but they do not have references as variables. Generally, both terms, constants, and literals are used interchangeably. -For example, “const int = 5;“, is a constant expression and the value 5 is referred to as a constant integer literal. -i. Integer Literals: -- Integer literals represent whole numbers without any fractional part. -- They can be positive or negative. -```c++ -Examples: -Decimal Integer: 42, -123 -Octal Integer: 012, 077 -Hexadecimal Integer: 0xff, 0x2a -Binary Integer (Java SE 7 and above): 0b1010101 -``` -ii. Floating Point Literals: -- Floating-point literals represent decimal numbers with a fractional part. -- They can be either single-precision (float) or double-precision (double). -```c++ -Examples: -3.14, -0.005, 2.71828 -``` -iii. Character Literals: --Character literals represent single characters enclosed in single quotes. -```c++ -Examples: -'A', 'b', '1' -``` -iv. String Literals: --String literals represent sequences of characters enclosed in double quotes. -```c++ -Example: -"Hello, World!" -``` -v. Boolean Literals: -- Boolean literals represent the truth values true or false. -```c++ -Example: -true, false -``` -vi. Pointer Literals: -Pointer literals are memory addresses represented as hexadecimal values. -```c++ -Example: -nullptr (represents a null pointer) -``` -### 6. Types of Constants in C++ -i. Integer Constants: -- Integer constants represent whole numbers without any fractional part. -- They can be positive or negative. -```c++ -Examples: -Decimal Integer: 42, -123 -Octal Integer: 012, 077 -Hexadecimal Integer: 0xff, 0x2a -Binary Integer (since C23): 0b1010101 -``` -ii. Floating Point Constants: -- Floating-point constants represent decimal numbers with a fractional part. -- They can be either single-precision (float) or double-precision (double). -```c++ -Examples: -3.14, -0.005, 2.71828 -``` -iii. Character Constants: -Character constants represent single characters enclosed in single quotes. -```c++ -Examples: -'A', 'b', '1' -``` -iv. String Constants: -- String constants represent sequences of characters enclosed in double quotes. -```c++ -Example: -"Hello, World!" -``` -v. Boolean Constants: -- Boolean constants represent the truth values true or false. -```c++ -Example: -true, false -``` -vi. Pointer Constants: -- Pointer constants are memory addresses represented as hexadecimal values. -```c++ -Example: -nullptr (represents a null pointer) -``` - - diff --git a/docs/day-04/_category_.json b/docs/day-04/_category_.json deleted file mode 100644 index 69bcfe455..000000000 --- a/docs/day-04/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 04", - "position": 5, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-04/constants-in-cpp.md b/docs/day-04/constants-in-cpp.md deleted file mode 100644 index 79111e3a0..000000000 --- a/docs/day-04/constants-in-cpp.md +++ /dev/null @@ -1,89 +0,0 @@ ---- -sidebar_position: 1 -title: "Constants in C++" -description: "The C++ const keyword is used to specify that the value of a variable cannot be changed. In this tutorial, you will learn about C++ constants with the help of examples." -sidebar_label: "Constants" -slug: constants-in-cpp ---- - -## What is Constants in C++? -Constants in C++ are fixed values that cannot be altered during the execution of a program. They are used to define values that should remain unchanged throughout the program, providing a way to ensure data integrity and improving code readability. - - - -IMAGE FILE: -![Constants in CPP](../../static/img/day-04/constants-in-cpp.png) - -## How to Declare Constants in C++? -Constants can be declared in C++ using the `const` keyword. The `const` keyword is placed before the data type of the variable to indicate that its value will not change. - -### Example: -```cpp -const int DAYS_IN_WEEK = 7; -const float PI = 3.14159; -``` - -## How to Define Constants in C++? -Constants are defined at the time of declaration by assigning them a fixed value. Once defined, their value cannot be modified. - -### Example: -```cpp -const double GRAVITY = 9.81; // gravitational constant in m/s^2 -const char NEWLINE = '\n'; // newline character -``` - -## How to Use Constants in C++? -Constants are used just like regular variables in expressions, function calls, and other places where a variable would be used. The key difference is that their value remains unchanged. - -### Example - -```cpp -const int MAX_USERS = 100; - -int main() { - int users = MAX_USERS; - std::cout << "Maximum number of users: " << users << std::endl; - return 0; -} -``` - -## What are the Advantages of Constants in C++? -- Readability: Constants make the code more readable by giving meaningful names to fixed values. -- Maintainability: Constants allow easy modification of values without changing multiple instances in the code. -- Safety: Constants prevent accidental modification of values that should remain fixed, reducing bugs and errors. -- Optimization: Constants can sometimes allow the compiler to optimize the code better since their values are known at compile time. - -## Best Practices for Using Constants in C++: -- Use Descriptive Names: Choose names that clearly describe the value or purpose of the constant. -- All Uppercase with Underscores: Use all uppercase letters with underscores to separate words for naming constants, making them easily distinguishable from variables. -- Define Constants at the Top: Define all constants at the beginning of the file or in a dedicated section for easy reference and modification. -- Group Related Constants: Group related constants together to improve code organization. -- Use constexpr for Compile-Time Constants: Use constexpr when the constant value can be determined at compile time for better performance. - -### Example: -```cpp -constexpr int ARRAY_SIZE = 50; -const double SPEED_OF_LIGHT = 299792458.0; // in meters per second -``` - -## Examples of Constants in C++ - -```cpp -#include <iostream> - -const int MAX_AGE = 120; -constexpr double PLANCK_CONSTANT = 6.62607015e-34; - -int main() { - const char GRADE = 'A'; - const std::string SCHOOL_NAME = "Greenwood High"; - - std::cout << "Max age allowed: " << MAX_AGE << std::endl; - std::cout << "Planck constant: " << PLANCK_CONSTANT << std::endl; - std::cout << "Grade: " << GRADE << std::endl; - std::cout << "School name: " << SCHOOL_NAME << std::endl; - - return 0; -} -``` - diff --git a/docs/day-04/input-output-in-cpp.md b/docs/day-04/input-output-in-cpp.md deleted file mode 100644 index 9c2ff5238..000000000 --- a/docs/day-04/input-output-in-cpp.md +++ /dev/null @@ -1,67 +0,0 @@ ---- -sidebar_position: 2 -title: "Input and Output in C++" -description: "In this tutorial, we will learn to use the cin object to take input from the user, and the cout object to display output to the user with the help of examples." -sidebar_label: "Input and Output" -slug: input-output-in-cpp ---- - -## What is Input and Output in C++? - -Input and Output (I/O) in C++ refer to the process of communicating with the user or other parts of the program. Input typically involves receiving data from an external source, such as the user via keyboard, or from a file. Output involves displaying information to the user, writing data to files, or sending data to other devices. - - - - -IMAGE FILE: -![Input Output in CPP](../../static/img/day-04/input-output-in-cpp.png) - - -## Why do we use Input and Output in C++? - -Input and Output are essential for creating interactive programs. They allow users to provide input to the program, which can then process the data and produce output, making the program more useful and versatile. - -## How to take input from the user in C++? - -In C++, you can take input from the user using the `std::cin` object, which is part of the `<iostream>` library. Here's an example: - -```cpp -#include <iostream> - -int main() { - int num; - std::cout << "Enter a number: "; - std::cin >> num; - std::cout << "You entered: " << num << std::endl; - return 0; -} -``` - -## How to display output to the user in C++? - -To display output to the user in C++, you can use the `std::cout` object, also part of the `<iostream>` library. Here's an example: - -```cpp -#include <iostream> - -int main() { - std::cout << "Hello, world!" << std::endl; - return 0; -} -``` - -## Take Multiple Inputs from the User in C++ - -To take multiple inputs from the user in C++, you can simply use multiple `std::cin` statements. Here's an example: - -```cpp -#include <iostream> - -int main() { - int num1, num2; - std::cout << "Enter two numbers: "; - std::cin >> num1 >> num2; - std::cout << "Sum: " << num1 + num2 << std::endl; - return 0; -} -``` diff --git a/docs/day-04/operators-in-cpp.md b/docs/day-04/operators-in-cpp.md deleted file mode 100644 index b2900319f..000000000 --- a/docs/day-04/operators-in-cpp.md +++ /dev/null @@ -1,362 +0,0 @@ ---- -sidebar_position: 3 -title: "Operators in C++" -description: "In this tutorial, we will learn about the different types of operators in C++ with the help of examples. In programming, an operator is a symbol that operates on a value or a variable." -sidebar_label: "Operators" -slug: operators-in-cpp ---- - -## 1. What is Operators in C++? - -In programming, an operator is a symbol that operates on a value or a variable. Operators are essential building blocks in C++, allowing you to perform various operations on data, such as arithmetic calculations, comparisons, and logical operations.--- - -![Operator in CPP](../../static/img/day-04/operator-in-cpp.png) - -## 2. Types of Operators in C++ - -Operators in C++ can be broadly categorized into several types: - -1. Arithmetic Operators -2. Relational Operators -3. Logical Operators -4. Bitwise Operators -5. Assignment Operators -6. Increment and Decrement Operators -7. Conditional (Ternary) Operator -8. Compound Operators -9. `sizeof` Operator -10. Comma Operator--- - -## 3. Explain All the Operators in C++ with Proper Examples - -### 1. Arithmetic Operators - -Arithmetic operators are used to perform basic mathematical operations. Here are the common arithmetic operators in C++: - -- **Addition (+)** : Adds two operands. -- **Subtraction (-)** : Subtracts the second operand from the first. -- **Multiplication (\*)** : Multiplies two operands. -- **Division (/)** : Divides the first operand by the second. -- **Modulus (%)** : Returns the remainder of a division operation. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10, b = 3; - cout << "a + b = " << a + b << endl; // Output: 13 - cout << "a - b = " << a - b << endl; // Output: 7 - cout << "a * b = " << a * b << endl; // Output: 30 - cout << "a / b = " << a / b << endl; // Output: 3 - cout << "a % b = " << a % b << endl; // Output: 1 - return 0; -} -``` - -### 2. Relational Operators - -Relational operators are used to compare two values. They return a boolean result (`true` or `false`). - -- **Equal to (==)** : Returns `true` if both operands are equal. -- **Not equal to (!=)** : Returns `true` if operands are not equal. -- **Greater than (>)** : Returns `true` if the first operand is greater than the second. -- **Less than ({'<'})** : Returns `true` if the first operand is less than the second. -- **Greater than or equal to (>=)** : Returns `true` if the first operand is greater than or equal to the second. -- **Less than or equal to ({'<'}=)** : Returns `true` if the first operand is less than or equal to the second. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10, b = 20; - cout << (a == b) << endl; // Output: 0 (false) - cout << (a != b) << endl; // Output: 1 (true) - cout << (a > b) << endl; // Output: 0 (false) - cout << (a < b) << endl; // Output: 1 (true) - cout << (a >= b) << endl; // Output: 0 (false) - cout << (a <= b) << endl; // Output: 1 (true) - return 0; -} -``` - -### 3. Logical Operators - -Logical operators are used to perform logical operations, often with boolean values. - -- **Logical AND (&&)** : Returns `true` if both operands are true. -- **Logical OR (||)** : Returns `true` if at least one of the operands is true. -- **Logical NOT (!)** : Returns `true` if the operand is false, and `false` if the operand is true. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - bool a = true, b = false; - cout << (a && b) << endl; // Output: 0 (false) - cout << (a || b) << endl; // Output: 1 (true) - cout << (!a) << endl; // Output: 0 (false) - cout << (!b) << endl; // Output: 1 (true) - return 0; -} -``` - -### 4. Bitwise Operators - -Bitwise operators perform bit-by-bit operations on integer data types. - -- **AND (&)** : Performs a bitwise AND operation. -- **OR (|)** : Performs a bitwise OR operation. -- **XOR (^)** : Performs a bitwise XOR operation. -- **NOT (~)** : Performs a bitwise NOT operation. -- **Left shift ({'<'}{'<'})** : Shifts bits to the left. -- **Right shift (>>)** : Shifts bits to the right. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 5; // 0101 in binary - int b = 3; // 0011 in binary - cout << (a & b) << endl; // Output: 1 (0001 in binary) - cout << (a | b) << endl; // Output: 7 (0111 in binary) - cout << (a ^ b) << endl; // Output: 6 (0110 in binary) - cout << (~a) << endl; // Output: -6 (Two's complement of 0101) - cout << (a << 1) << endl; // Output: 10 (1010 in binary) - cout << (a >> 1) << endl; // Output: 2 (0010 in binary) - return 0; -} -``` - -### 5. Assignment Operators - -Assignment operators are used to assign values to variables. Here are some commonly used assignment operators: - -- **Assign (=)** : Assigns the right operand to the left operand. -- **Add and assign (+=)** : Adds the right operand to the left operand and assigns the result to the left operand. -- **Subtract and assign (-=)** : Subtracts the right operand from the left operand and assigns the result to the left operand. -- **Multiply and assign (\*=)** : Multiplies the right operand with the left operand and assigns the result to the left operand. -- **Divide and assign (/=)** : Divides the left operand by the right operand and assigns the result to the left operand. -- **Modulus and assign (%=)** : Computes the modulus using the two operands and assigns the result to the left operand. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10; - a += 5; // Equivalent to a = a + 5 - cout << a << endl; // Output: 15 - a -= 3; // Equivalent to a = a - 3 - cout << a << endl; // Output: 12 - a *= 2; // Equivalent to a = a * 2 - cout << a << endl; // Output: 24 - a /= 4; // Equivalent to a = a / 4 - cout << a << endl; // Output: 6 - a %= 5; // Equivalent to a = a % 5 - cout << a << endl; // Output: 1 - return 0; -} -``` - -### 6. Increment and Decrement Operators - -Increment and decrement operators are used to increase or decrease the value of a variable by one. - -- **Increment (++)** : Increases the value of a variable by one. -- **Decrement (--)** : Decreases the value of a variable by one. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10; - cout << "a = " << a << endl; // Output: a = 10 - a++; - cout << "a++ = " << a << endl; // Output: a++ = 11 - a--; - cout << "a-- = " << a << endl; // Output: a-- = 10 - return 0; -} -``` - -### 7. Conditional (Ternary) Operator - -The conditional operator (?:) is a shorthand for an `if-else` statement. It takes three operands. - -**Syntax:** - -```css -condition ? expression1 : expression2; -``` - -If the condition is true, it evaluates `expression1`; otherwise, it evaluates `expression2`. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10, b = 20; - int max = (a > b) ? a : b; - cout << "The maximum value is " << max << endl; // Output: The maximum value is 20 - return 0; -} -``` - -### 8. Compound Operators - -Compound operators combine an arithmetic operator with an assignment operator. - -- **Add and assign (+=)** -- **Subtract and assign (-=)** -- **Multiply and assign (\*=)** -- **Divide and assign (/=)** -- **Modulus and assign (%=)** - -These operators have already been covered under assignment operators. - -### 9. `sizeof` Operator - -The `sizeof` operator is used to determine the size of a data type or a variable in bytes. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - cout << "Size of int: " << sizeof(int) << " bytes" << endl; // Output: 4 bytes - cout << "Size of double: " << sizeof(double) << " bytes" << endl; // Output: 8 bytes - int a; - cout << "Size of variable a: " << sizeof(a) << " bytes" << endl; // Output: 4 bytes - return 0; -} -``` - -### 10. Comma Operator - -The comma operator (,) is used to separate two or more expressions. The expressions are evaluated from left to right, and the value of the rightmost expression is the result. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a, b; - a = (b = 3, b + 2); - cout << "a = " << a << endl; // Output: a = 5 - return 0; -} -``` -## 4. Operator Overloading - -### Introduction - -Operator overloading allows you to redefine the way operators work for user-defined types (classes and structs). It enables you to specify more intuitive ways to perform operations on objects of your classes. - -Overloading an operator does not change: -- the operator precedence, -- the associativity of the operator, -- the arity of the operator, or -- the meaning of how the operator works on objects of -built-in types. - -### Syntax -An overloaded operator is implemented as a special member function with the keyword `operator` followed by the symbol of the operator being overloaded. - -```cpp -class ClassName { -public: - ReturnType operatorOpSymbol (ParameterList) { - // Function body - } -}; -``` - -### Example -```cpp -class Complex { -public: - double real, imag; - - Complex(double r = 0, double i = 0) : real(r), imag(i) {} - - // Overload the + operator - Complex operator+ (Complex& obj) { - return Complex(real + obj.real, imag + obj.imag); - } -}; -``` - -### Types of Operators that Can Be Overloaded - -- Arithmetic operators: `+`, `-`, `*`, `/`, `%` -- Relational operators: `==`, `!=`, `<`, `>`, `<=`, `>=` -- Logical operators: `&&`, `||`, `!` -- Bitwise operators: `&`, `|`, `^`, `~`, `<<`, `>>` -- Increment and decrement operators: `++`, `--` -- Assignment operators: `=`, `+=`, `-=`, `*=`, `/=`, `%=` -- Subscript operator: `[]` -- Function call operator: `()` -- Member access operators: `->`, `.` (only for pointers to members) -- Input and output operators: `>>`, `<<` - -Operators that **cannot** be overloaded include: `::`, `.*`, `.`, `? :`, `sizeof` - -### Example: -```cpp -#include <iostream> - -class Complex { -public: - double real, imag; - - Complex(double r = 0, double i = 0) : real(r), imag(i) {} - - // Overload the == operator - bool operator== (const Complex& obj) const { - return (real == obj.real && imag == obj.imag); - } -}; - -int main() { - Complex c1(3.0, 4.0), c2(3.0, 4.0); - if (c1 == c2) { - std::cout << "c1 and c2 are equal" << std::endl; - } else { - std::cout << "c1 and c2 are not equal" << std::endl; - } - return 0; -} -``` - -### Operator Overloading Rules - -When overloading operators, there are several rules to keep in mind: - -1. **Preserve the Operator's Original Meaning**: The overloaded operator should make sense in the context of the operation it performs. -2. **Return Types**: The return type should be appropriate for the operation. For example, `operator+` should return a new object, while `operator+=` should return a reference to `*this`. -3. **Symmetry**: Ensure symmetric behavior where applicable. For example, `a == b` should return the same result as `b == a`. -4. **Do Not Overload Operators Irrelevantly**: Only overload operators that make sense for your class. For example, overloading the arithmetic operators for a class that represents a complex number makes sense, but overloading them for a class that represents a database connection does not. diff --git a/docs/day-05/Logical Operators.md b/docs/day-05/Logical Operators.md deleted file mode 100644 index 97fe28e4b..000000000 --- a/docs/day-05/Logical Operators.md +++ /dev/null @@ -1,53 +0,0 @@ ---- -sidebar_position: 6 -title: "Logical Operators" -description: "In this tutorial, we will learn about Logical Operators in C++ programming with the help of examples." -sidebar_label: "Logical Operators" -slug: Logical-Operators-cpp ---- -# Logical Operators in C++ - -This repository provides an explanation of logical operators in C++, along with examples of their usage. - -## Table of Contents - -- [Introduction](#introduction) -- [Logical Operators](#logical-operators) - - [AND (`&&`)](#and-) - - [OR (`||`)](#or-) - - [NOT (`!`)](#not-) -- [Examples](#examples) - -## Introduction - -Logical operators in C++ are used to perform logical operations on boolean operands. This document provides an overview of these operators and demonstrates their usage through examples. - -## Logical Operators - -### AND (`&&`) - -The AND operator returns `true` if both operands are `true`, otherwise it returns `false`. - -### OR (`||`) - -The OR operator returns `true` if at least one of the operands is `true`, otherwise it returns `false`. - -### NOT (`!`) - -The NOT operator negates the value of its operand. If the operand is `true`, it returns `false`, and if the operand is `false`, it returns `true`. - -## Examples - -```cpp -bool a = true; -bool b = false; - -// Using AND operator -bool result = (a && b); // result will be false - -// Using OR operator -result = (a || b); // result will be true - -// Using NOT operator -result = !a; // result will be false -``` \ No newline at end of file diff --git a/docs/day-05/_category_.json b/docs/day-05/_category_.json deleted file mode 100644 index 47132fb0c..000000000 --- a/docs/day-05/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 05", - "position": 6, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-05/arithmetic-Operators.md b/docs/day-05/arithmetic-Operators.md deleted file mode 100644 index e41d5e62b..000000000 --- a/docs/day-05/arithmetic-Operators.md +++ /dev/null @@ -1,67 +0,0 @@ ---- -sidebar_position: 4 -title: "Arithmetic Operators" -description: "In this tutorial, we will learn about Arithmetic Operators in C++ programming with the help of examples." -sidebar_label: "Arithmetic Operators" -slug: Arithmetic-Operators-cpp ---- - -# Arithmetic Operators in C++ - -Arithmetic operators in C++ are symbols used to perform mathematical operations on operands. These operators allow you to perform addition, subtraction, multiplication, division, and modulus operations. - -## Addition (+) - -Adds two operands together. - -```cpp - -int result = 5 + 3; // result will be 8 - -``` -## Subtraction (-) - -Subtracts the right operand from the left operand. - -```cpp - -int result = 7 - 4; // result will be 3 - -``` -## Multiplication (*) - -Multiplies two operands. - -```cpp - -int result = 6 * 2; // result will be 12 - -``` - -## Division (/) - -Divides the left operand by the right operand. If both operands are integers, the result will be an integer, with any remainder discarded. - -```cpp - -int result = 10 / 3; // result will be 3 - -``` -If you want to get a floating-point result, you can use floating-point operands: - -```cpp - -double result = 10.0 / 3.0; // result will be approximately 3.33333 - -``` - -## Modulus (%) - -Returns the remainder of the division of the left operand by the right operand. - -```cpp - -int result = 10 % 3; // result will be 1 - -``` -These operators can be used with variables, constants, or expressions. They follow the usual rules of precedence and associativity. Additionally, parentheses can be used to enforce a specific order of evaluation. diff --git a/docs/day-05/do-while-loop.md b/docs/day-05/do-while-loop.md deleted file mode 100644 index 3f225d43a..000000000 --- a/docs/day-05/do-while-loop.md +++ /dev/null @@ -1,112 +0,0 @@ ---- -sidebar_position: 3 -title: "While and Do-While Loop in C++" -description: "In this tutorial, we will learn about the while and do-while loop in C++ programming with the help of examples. The while loop is used to execute a block of code multiple times." -sidebar_label: "While and Do-While Loop" -slug: while-and-do-while-loop-in-cpp ---- - - -## while Loop - -A `while` loop in C++ repeatedly executes a block of statements as long as a specified condition is true. The condition is evaluated before the execution of the loop's body. - -![Do While Loop](../../static/img/day-05/while-do-while-loop-in-cpp.png) - - - - -### Flowchart of while Loop - -```plaintext - +----------------------+ - | Start | - +----------------------+ - | - v - +----------------------+ - | Condition? | - +----------------------+ - | | - | v - True False - | | - v v -+----------------+ | -| Loop Body | | -+----------------+ | - | | - +----------+ - | - v - +----------------------+ - | End | - +----------------------+ -``` - -### Example 1: Display Numbers from 1 to 5 - -```cpp -#include <iostream> - -int main() { - int i = 1; - while (i <= 5) { - std::cout << i << std::endl; - i++; - } - return 0; -} -``` - -## do...while Loop - -A `do...while` loop in C++ is similar to a `while` loop, except that the condition is evaluated after the execution of the loop's body. This guarantees that the loop body is executed at least once. - -### Flowchart of do...while Loop - -```plaintext - +----------------------+ - | Start | - +----------------------+ - | - v - +----------------------+ - | Loop Body | - +----------------------+ - | - v - +----------------------+ - | Condition? | - +----------------------+ - | | - | v - True False - | | - v v -+----------------+ | -| Loop Body | | -+----------------+ | - | | - +----------+ - | - v - +----------------------+ - | End | - +----------------------+ -``` - -### Example 2: Display Numbers from 1 to 5 - -```cpp -#include <iostream> - -int main() { - int i = 1; - do { - std::cout << i << std::endl; - i++; - } while (i <= 5); - return 0; -} -``` diff --git a/docs/day-05/for-loop.md b/docs/day-05/for-loop.md deleted file mode 100644 index 18c29d3a8..000000000 --- a/docs/day-05/for-loop.md +++ /dev/null @@ -1,140 +0,0 @@ ---- -sidebar_position: 2 -title: "For Loop in C++" -description: "In this tutorial, we will learn about the for loop in C++ programming with the help of examples. The for loop is used to execute a block of code multiple times." -sidebar_label: "For Loop" -slug: for-loop-in-cpp ---- - - -# C++ For Loop - -## What is the For Loop in C++? -A for loop in C++ is a fundamental control structure used to execute a block of code multiple times. It is particularly useful when the number of iterations is known before the loop starts. The for loop is one of the most versatile loops in C++ and allows for concise and clear code. It consists of three main parts: initialization, condition checking, and increment/decrement. These parts are usually handled within the loop statement, making the for loop compact and easy to understand. - -![For Loop](../../static/img/day-05/for-loop-in-cpp.png) - -## Syntax of For Loop in C++ -The for loop in C++ has a specific syntax that needs to be followed. Here’s the breakdown: - -```cpp -for (initialization; condition; increment/decrement) { - // Code to be executed -} -``` -- **Initialization**: This step is executed once at the beginning of the loop. It’s used to initialize loop control variables. For example, int i = 0;. - -- **Condition**: This boolean expression is evaluated before each iteration of the loop. If the condition is true, the loop body is executed. If it’s false, the loop terminates. For example, i < 10. - -- **Increment / Decrement**: This step is executed after each iteration of the loop body. It’s used to update the loop control variables. For example, i++ or i += 2. - -Here is a practical example: -```cpp -#include <iostream> -using namespace std; - -int main() { - - for (int i = 0; i < 10; i++) { - cout << "Iteration: " << i << endl; - } - - return 0; -} -``` - -In this example: - -- The loop starts with i = 0. - -- It checks the condition i < 10. - - If the condition is true, it prints the value of iand increments i by 1. -- The loop repeats until i is no longer less than 10. - -## C++ for Loop - -Let's look at a more detailed example that calculates the sum of the first 10 natural numbers: - -```cpp -#include <iostream> -using namespace std; - -int main() { - int sum = 0; - - for (int i = 1; i <= 10; i++) { - sum += i; - } - - cout << "The sum of the first 10 natural numbers is: " << sum << endl; - return 0; -} -``` - -In this example: - -- We initialize sum to 0. - -- The loop variable i starts at 1 and increments until it reaches 10. - - In each iteration, the value of i is added to sum. -- After the loop ends, the sum is printed. - -## 4. C++ Infinite for Loop -An infinite for loop runs indefinitely because the terminating condition is never met. This can be useful in programs that need to run continuously until an external event occurs, such as user input or a signal from another part of the program. - -Here is an example of an infinite for loop: - -```cpp -#include <iostream> -using namespace std; - -int main() { - for (;;) { - cout << "This loop will run forever" << endl; - // You can include a break condition to exit the loop - // For example, if you want to break the loop after some condition - // if (someCondition) break; - } - return 0; -} -``` - -In this example: - -- The initialization, condition, and increment/decrement are omitted. - -- The loop runs forever, repeatedly printing the message. - -- A break statement can be added to exit the loop based on a specific condition. - -## 5. C++ Nested for Loop - -Nested for loops are loops within loops. They are often used to work with multi-dimensional data structures, like matrices or tables. Here’s an example of nested for loops to print a multiplication table: - -```cpp -#include <iostream> -using namespace std; - -int main() { - for (int i = 1; i <= 10; i++) { - - for (int j = 1; j <= 10; j++) { - cout << i << " * " << j << " = " << i * j << "\t"; - } - - cout << endl; - } - - return 0; -} -``` - -In this example: - -- The outer loop iterates from 1 to 10 (rows of the table). - -- The inner loop iterates from 1 to 10 for each iteration of the outer loop (columns of the table). - -- The product of i and j is printed, resulting in a multiplication table. - -- Each row of the table is printed by the inner loop, and after the inner loop completes, a new line is started by the outer loop. \ No newline at end of file diff --git a/docs/day-05/if-else-statement.md b/docs/day-05/if-else-statement.md deleted file mode 100644 index 58c6ac3f7..000000000 --- a/docs/day-05/if-else-statement.md +++ /dev/null @@ -1,134 +0,0 @@ ---- -sidebar_position: 1 -title: "IF-ELSE Statement in C++" -description: "The if...else statement is used to run one block of code under certain conditions and another block of code under different conditions. In this tutorial, we will learn C++ if, if…else and nested if…else with the help of examples.." -sidebar_label: "IF-ELSE Statement" -slug: if-else-statement-in-cpp ---- - - -## 1. What is Control Statements in C++? -Control statements are the keywords and judgement makers of C++, which controls the run time process of a program. These statements enable the program to decide on a course of action, to compute repetitive tasks and to determine the program’s flow according to specific conditions that may have been defined in the statements. There are two primary types of control statements in C++: - - Conditionals - - Loops - -**Conditional Statements** -Conditional Statements are block of statements used to execute code based on a certain condition. -There are two types: `if-else` and `Switch` statements. - -**Loop Statements** -Loop statements are used to repeat certain task or a block of code. -Types are: `for`, `while` and `do-while` Loops. - - -![if else in cpp](../../static/img/day-05/if-else-statement.png) - - -## 2. What is the IF-ELSE Statement in C++? -The IF-ELSE statement in C++ is a conditional statement that executes different code blocks based on whether a given condition is `true` or `false`. This is a fundamental concept in programming that allows for decision-making and branching in the code. - -### Syntax - -```cpp -if (condition) { - // Code to execute if condition is true -} else { - // Code to execute if condition is false -} -``` - -## 3. C++ if Statement -The simplest form of the conditional statement that executes a block of code if the condition is `true`. - -### Example -```cpp -#include<iostream> -using namespace std; - -int main(){ - int x = 10; - - if(x > 5){ - cout<<"the number is greater than 5"<<endl; - } -} -``` -## 4. C++ if-else Statement -An extension of the if statement that includes an else block to execute code if the condition is `false`. - -### Example -```cpp -#include<iostream> -using namespace std; - -int main(){ - int x = 10; - - if (x > 15) { - cout << "x is greater than 15"; - } else { - cout << "x is not greater than 15"; - } -} -``` - -## 5. C++ Nested if-else Statement -You can also nest if-else statements inside another if or else block to create more complex conditions. - -### Example -```cpp -#include<iostream> -using namespace std; - -int main(){ - int x = 10; - int y = 20; - if (x > 5) { - if (y > 15) { - cout << "x is greater than 5 and y is greater than 15"; - } else { - cout << "x is greater than 5 but y is not greater than 15"; - } - } else { - cout << "x is not greater than 5"; - } -} -``` -## 6. C++ if-else-if Ladder -This is used when you have multiple conditions to evaluate. Each condition is checked in sequence, and the block of code for the first true condition is executed. - -### Example -```cpp -#include<iostream> -using namespace std; - -int main(){ - int x = 10; - if (x == 10) { - cout << "x is 10"; - } else if (x == 20) { - cout << "x is 20"; - } else if (x == 30) { - cout << "x is 30"; - } else { - cout << "x is not 10, 20, or 30"; - } -} - -``` -## 7. C++ Ternary Operator -The ternary operator is a shorthand way to write simple if-else statements. It is also known as the conditional operator. - -### Example -```cpp -#include<iostream> -using namespace std; - -int main(){ - int x = 10; - string result = (x > 5) ? "x is greater than 5" : "x is not greater than 5"; - cout << result; -} -``` -NOTE: -> In the above code "?" refers to if-statement and statement after the ":" is executed if the if-statement is `false`. diff --git a/docs/day-05/relational_operators.md b/docs/day-05/relational_operators.md deleted file mode 100644 index a2e6ea923..000000000 --- a/docs/day-05/relational_operators.md +++ /dev/null @@ -1,75 +0,0 @@ ---- -sidebar_position: 5 -title: "Relational Operators" -description: "In this tutorial, we will learn about Relational Operators in C++ programming with the help of examples." -sidebar_label: "Relational Operators" -slug: Relational-Operators-cpp ---- - -# Relational Operators in C++ - -Relational operators in C++ are used to compare two values and determine the relationship between them. These operators return a boolean value of true or false based on whether the comparison is true or false. Here are the commonly used relational operators: - -## Equal to (==) - -Compares if two operands are equal. Returns true if they are equal, false otherwise. - -```cpp -int a = 5, b = 5; -if (a == b) { - // This block will be executed because a is equal to b -} -``` - -## Not equal to (!=) - -Compares if two operands are not equal. Returns true if they are not equal, false otherwise. - -```cpp -int a = 5, b = 10; -if (a != b) { - // This block will be executed because a is not equal to b -} -``` -## Greater than (>) - -Checks if the left operand is greater than the right operand. Returns true if it is, false otherwise. - -```cpp -int a = 10, b = 5; -if (a > b) { - // This block will be executed because a is greater than b -} -``` - -## Less than ( < ) -Checks if the left operand is less than the right operand. Returns true if it is, false otherwise. - -```cpp -int a = 5, b = 10; -if (a < b) { - // This block will be executed because a is less than b -} - -``` -## Greater than or equal to (>=) - -Checks if the left operand is greater than or equal to the right operand. Returns true if it is, false otherwise. - -```cpp -int a = 10, b = 5; -if (a >= b) { - // This block will be executed because a is greater than or equal to b -} -``` -## Less than or equal to (< =) - -Checks if the left operand is less than or equal to the right operand. Returns true if it is, false otherwise. - -```cpp -int a = 5, b = 10; -if (a <= b) { - // This block will be executed because a is less than or equal to b -} - -``` \ No newline at end of file diff --git a/docs/day-06/If-statement.md b/docs/day-06/If-statement.md deleted file mode 100644 index b7436c00f..000000000 --- a/docs/day-06/If-statement.md +++ /dev/null @@ -1,79 +0,0 @@ ---- -sidebar_position: 4 -title: "If Statements in C++" -description: "In this tutorial, we will learn about the If Statements in C++ programming with the help of examples. The If statement is used to conditional execution." -sidebar_label: "If Statements in C++" -slug: If-Statements ---- -# If Statements in C++ - -This repository provides an explanation of if statements in C++, along with examples of their usage. - -## Table of Contents - -- [Introduction](#introduction) -- [Basic If Statement](#basic-if-statement) -- [If-Else Statement](#if-else-statement) -- [Nested If Statements](#nested-if-statements) -- [If-Else If-Else Ladder](#if-else-if-else-ladder) -## Introduction - -If statements in C++ are used for conditional execution, allowing you to control the flow of your program based on certain conditions. - -## Basic If Statement - -```cpp -int x = 10; - -if (x > 5) { - std::cout << "x is greater than 5" << std::endl; -} -``` -In this example, the condition `x > 5` is evaluated. If it's true (which it is, since `x` is `10`), the code inside the curly braces `{}` is executed, and "x is greater than 5" is printed.` - -## If-Else Statement - -```cpp -int y = 2; - -if (y % 2 == 0) { - std::cout << "y is even" << std::endl; -} else { - std::cout << "y is odd" << std::endl; -} - -``` -In this example, if `y` is divisible by `2` (i.e., it's an even number), the first block of code is executed. Otherwise, if the condition is false, the code inside the `else` block is executed.` - -## Nested If Statements - -```cpp -int a = 5; -int b = 10; - -if (a > 0) { - if (b > 5) { - std::cout << "Both a and b are positive and b is greater than 5" << std::endl; - } -} - -``` -Here, we have an if statement nested inside another if statement. Both conditions must be true for the inner block of code to execute. - -## If-Else If-Else Ladder - -```cpp -int mark = 70; - -if (mark >= 90) { - std::cout << "Grade A" << std::endl; -} else if (mark >= 80) { - std::cout << "Grade B" << std::endl; -} else if (mark >= 70) { - std::cout << "Grade C" << std::endl; -} else { - std::cout << "Grade D" << std::endl; -} - -``` -In this example, the program checks the value of `mark` against multiple conditions in a sequential manner. Once a condition is met, the corresponding block of code is executed, and the rest of the conditions are skipped. \ No newline at end of file diff --git a/docs/day-06/_category_.json b/docs/day-06/_category_.json deleted file mode 100644 index d67bee4ff..000000000 --- a/docs/day-06/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 06", - "position": 7, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-06/break-statement.md b/docs/day-06/break-statement.md deleted file mode 100644 index 508fee79c..000000000 --- a/docs/day-06/break-statement.md +++ /dev/null @@ -1,72 +0,0 @@ ---- -sidebar_position: 1 -title: "Break Statement in C++" -description: "In this tutorial, we will learn about the break statement in C++ programming with the help of examples. The break statement is used to terminate the loop or switch statement." -sidebar_label: "Break Statement" -slug: break-statement-in-cpp ---- - -## What is the Break Statement in C++? -The break statement in C++ is a control statement used to exit prematurely from loops (like for, while, or do-while loops) and switch statements. When encountered, the break statement immediately terminates the loop it's contained within, regardless of the loop's normal exit conditions. This allows for an early exit based on certain conditions without executing the remaining code inside the loop. - - - - -![Constants in CPP](../../static/img/day-04/constants-in-cpp.png) - -## Explain the Syntax of Break Statement in C++. -The syntax of the break statement in C++ is simple and straightforward.It's used without any conditions or expressions. Here's the syntax: - -### Syntax of break statement: - -```cpp - break; - -``` -When encountered within a loop or a switch statement, the break statement immediately terminates the nearest enclosing loop or switch statement and transfers control to the statement immediately following the terminated loop or switch. - -## C++ Break Statement Example - -```cpp -#include <iostream> -using namespace std; - -int main() { - for (int i = 1; i <= 5; ++i) { - if (i == 3) { - cout << "Breaking out of the loop when i is 3." << endl; - break; - } - cout << i << " "; - } - return 0; -} - -``` - -## C++ Break Statement in Nested Loop. -The break statement can be especially helpful in C++ when utilising nested loops to manage the execution flow. It lets you break out of nested loops at any number of levels under specific circumstances. The following is an example of how to use break in nested loops: - -### Example - -```cpp -#include <iostream> -using namespace std; - -int main() { - for (int i = 1; i <= 3; ++i) { - cout << "Outer loop iteration: " << i << endl; - for (int j = 1; j <= 3; ++j) { - cout << "Inner loop iteration: " << j << endl; - if (j == 2) { - cout << "Breaking out of the inner loop." << endl; - break; // Exits the inner loop when j equals 2 - } - } - } - return 0; -} - -``` - - diff --git a/docs/day-06/continue-statement.md b/docs/day-06/continue-statement.md deleted file mode 100644 index 32be52b81..000000000 --- a/docs/day-06/continue-statement.md +++ /dev/null @@ -1,104 +0,0 @@ ---- -sidebar_position: 2 -title: "Continue Statement in C++" -description: "In this tutorial, we will learn about the continue statement in C++ programming with the help of examples. The continue statement is used to skip the current iteration of the loop and continue with the next iteration." -sidebar_label: "Continue Statement" -slug: continue-statement-in-cpp ---- -## What is the Continue Statement in C++? -In C++, the continue statement is used within loops to skip the rest of the current iteration and proceed directly to the next iteration of the loop. It's often used to avoid executing certain code in a loop under certain conditions. - - -### Example - -```cpp - #include <iostream> - using namespace std; - int main() { - for (int i = 1; i <= 5; ++i) { - if (i == 3) { - // Skip the rest of the iteration if i equals 3 - continue; - } - cout << "Current value of i: " << i <<endl; - } - return 0; -} - -``` - - -![Continue Statement](../../static/img/day-06/continue-statement.png) - -## Working of C++ continue Statement. - -The continue statement in C++ works by interrupting the current iteration of a loop and immediately jumping to the next iteration of the loop. When the continue statement is encountered within a loop, the rest of the code inside the loop's body for the current iteration is skipped, and the loop proceeds with the next iteration. - -### Steps: -1. The loop condition is evaluated. -2. If the loop condition is true, the code inside the loop's body is executed. -3. When the continue statement is encountered, the control immediately jumps to the next iteration of the loop, bypassing the remaining code inside the loop's body for the current iteration. -4. The loop condition is evaluated again, and the process continues until the loop condition becomes false or another control statement interrupts the loop. - - -## Example of Continue Statement in C++ with different loops. - -### for loop - -```cpp - - #include <iostream> - int main() { - for (int i = 1; i <= 5; ++i) { - if (i == 3) { - // Skip the rest of the iteration if i equals 3 - continue; - } - std::cout << "Current value of i: " << i << std::endl; - } - return 0; -} - -``` -### while loop - -```cpp - -#include <iostream> - -int main() { - int i = 1; - while (i <= 5) { - if (i == 3) { - // Skip the rest of the iteration if i equals 3 - ++i; - continue; - } - std::cout << "Current value of i: " << i << std::endl; - ++i; - } - return 0; -} - -``` -### do-while loop - -```cpp - -#include <iostream> - -int main() { - int i = 1; - do { - if (i == 3) { - // Skip the rest of the iteration if i equals 3 - ++i; - continue; - } - std::cout << "Current value of i: " << i << std::endl; - ++i; - } while (i <= 5); - return 0; -} - -``` diff --git a/docs/day-06/goto-statement.md b/docs/day-06/goto-statement.md deleted file mode 100644 index c66576830..000000000 --- a/docs/day-06/goto-statement.md +++ /dev/null @@ -1,44 +0,0 @@ ---- -sidebar_position: 3 -title: "Go To Statement in C++" -description: "In this tutorial, we will learn about the goto statement in C++ programming with the help of examples. The goto statement is used to transfer control to the other part of the program." -sidebar_label: "Go To Statement" -slug: goto-statement-in-cpp ---- - -`NOTE:` The `return` statement is necessary in the code corresponding to `positive` label, as, otherwise the code corresponding to `negative` label will also get executed. - - -## Why is the Go To Statement Considered Harmful? - -The use of `goto` statement is considered to be a bad programming practice and use of it is highly discouraged. This is beacause it makes the program logic complex and also makes it difficult for us to trace the control flow of program. `goto` statements can be avoided as any program with `goto` can be rewritten using `break` and `continue` statements. - - - -## When to Use Go To Statement in C++? -Although the use of the `goto` statement is generally discouraged, there are specific cases where it can be useful. For instance, in a program with multiple nested loops, you might want to break out of all the loops simultaneously. Normally, this would require multiple `break` statements for each loop level. However, a single `goto` statement can achieve the same result more efficiently. - -# 4. Why is the Go To Statement Considered Harmful? - - -- Unstructured Code: "Go to" statements can lead to unstructured, spaghetti-like code. Programs with excessive "go to" statements become hard to read, understand, and maintain. Debugging such code can be a nightmare. - -- Difficulty in Control Flow Analysis: It becomes difficult to analyze and reason about the flow of control in programs that heavily use "go to" statements. This makes it harder to verify correctness and ensure robustness. - -- Code Obfuscation: "Go to" statements can obscure the logical flow of a program, making it challenging for other programmers (including your future self) to comprehend the code's intent and functionality. - -- Scope for Bugs and Errors: Misuse of "go to" statements can lead to subtle bugs and errors that are hard to detect and fix. It's easy to accidentally jump to the wrong part of the code or introduce unintended behavior. - -- Structured Programming Principles: The widespread adoption of structured programming principles advocates for the use of structured control flow constructs like loops, conditionals, and functions, which offer clearer program organization and better readability. - - - Portability and Maintainability: Code with "go to" statements can be less portable and harder to maintain. Modifying or extending such code becomes risky and error-prone. - -# 5. When to Use Go To Statement in C++? - -1. Breaking out of Nested Loops: Sometimes, you may encounter a situation where breaking out of nested loops using a "go to" statement could result in cleaner code than using nested break statements. - -2. Error Handling in Resource Cleanup: In scenarios where you need to perform resource cleanup (like closing files or releasing memory) when an error occurs, using a "go to" statement to jump to a common cleanup section can help avoid code duplication and ensure proper cleanup. - -3. Jumping within a Local Scope: Occasionally, in very specific algorithms or low-level code, jumping within a local scope using "go to" might provide a cleaner and more efficient solution compared to alternative approaches. However, this should be approached with caution and well-documented. - -4. Optimization in Performance-Critical Code: In rare cases where performance is critical and careful optimization is necessary, judicious use of "go to" might provide some benefits by avoiding unnecessary function calls or loop iterations. diff --git a/docs/day-07/_category_.json b/docs/day-07/_category_.json deleted file mode 100644 index 285ca7858..000000000 --- a/docs/day-07/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 07", - "position": 8, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-07/friend-and-virtual-functions-in-cpp.md b/docs/day-07/friend-and-virtual-functions-in-cpp.md deleted file mode 100644 index 64f257a72..000000000 --- a/docs/day-07/friend-and-virtual-functions-in-cpp.md +++ /dev/null @@ -1,124 +0,0 @@ -# Friend Functions - -A friend function is a function that is not a member of a class but has access to the class's private and protected members. It is declared within the class using the `friend` keyword. - -It used in the cases of **Operator Overloading** , accessing **Non-member functions**. - -Below is the flowchart for showing work of friend functions. - -```mermaid -flowchart TD - Start --> DefineClass - DefineClass --> DeclarePrivateMembers - DeclarePrivateMembers --> DeclareFriendFunction - DeclareFriendFunction --> CreateInstance - CreateInstance --> DefineFriendFunction - DefineFriendFunction --> CallFriendFunction - CallFriendFunction --> End - - subgraph Define and Declare - DefineClass[Define Class] - DeclarePrivateMembers[Declare Private Members] - DeclareFriendFunction[Declare Friend Function] - end - - subgraph Define and Use - CreateInstance[Create an Instance of the Class] - DefineFriendFunction[Define the Friend Function] - CallFriendFunction[Call Friend Function] - end - - End[End] -``` - -Example : - -```cpp -#include <iostream> -using namespace std; - -class Box { -private: - double width; - -public: - Box(double w) : width(w) {} - - // Friend function declaration - friend void printWidth(Box box); -}; - -// Friend function definition -void printWidth(Box box) { - cout << "Width of box: " << box.width << endl; -} - -int main() { - Box box(10.0); - printWidth(box); // Accesses private member of Box - return 0; -} -``` - - -# Virtual Functions - -A virtual function is a member function in a base class that can be overridden in a derived class. It is declared using the `virtual` keyword in the base class and allows dynamic (runtime) polymorphism. - -Here is the flowchart which gives idea behind virtual functions. - -```mermaid -graph TD - A[Start] --> B[Base Class] - B --> C[Virtual Function Declaration] - C --> D[Derived Class] - D --> E[Override Virtual Function] - E --> F[Create Object of Derived Class] - F --> G[Call Virtual Function] - G --> H[Derived Class Implementation] - H --> I[End] - - subgraph Virtual_Function_Process - D --> C - E --> F - end -``` - -Example : - -```cpp -#include <iostream> -using namespace std; - -class Base { -public: - virtual void display() { - cout << "Display of Base class" << endl; - } - - // Pure virtual function (abstract class) - virtual void pureVirtualFunction() = 0; -}; - -class Derived : public Base { -public: - void display() override { // Override the base class function - cout << "Display of Derived class" << endl; - } - - void pureVirtualFunction() override { - cout << "Implementation of pure virtual function in Derived class" << endl; - } -}; - -int main() { - Base* basePtr; - Derived derivedObj; - basePtr = &derivedObj; - - basePtr->display(); // Calls Derived's display function - basePtr->pureVirtualFunction(); // Calls Derived's implementation of pure virtual function - - return 0; -} -``` diff --git a/docs/day-07/function-in-cpp.md b/docs/day-07/function-in-cpp.md deleted file mode 100644 index 69a910b5f..000000000 --- a/docs/day-07/function-in-cpp.md +++ /dev/null @@ -1,129 +0,0 @@ ---- -sidebar_position: 3 -title: "Function in C++" -description: "In this tutorial, we will learn about functions in C++ programming with the help of examples. A function is a block of code that performs a specific task. It is used to break the code into smaller modules that can be reused." -sidebar_label: "Function" -slug: function-in-cpp ---- - - -## Functions in C++ - -In this tutorial, we will learn about functions in C++ programming with the help of examples. A function is a block of code that performs a specific task. It is used to break the code into smaller modules that can be reused. Think of it as an independent unit that takes some input (parameters), performs some operations, and returns an output (or no output if not specified). They are used to organize, improve code readability, and make code reusable. - -**Function Syntax:** - -```c++ -return_type function_name(parameter_list) { - // Body of the function - return value; -} -``` - -The above statement is an example of a function declaration in C++. It suggests that to declare a function, its `return type`, `function name`, and `parameter list` must be declared. - -**Example:** - -```c++ -int add(int a, int b) { - return a + b; -} -``` - -This function takes two integers as parameters and returns their sum. To call the function, you would simply write: - -```c++ -int sum = add(1, 2); -``` - -**How to Declare a Function:** - -To declare a function in C++, we must first define its return type: - -* `void`: Indicates the function doesn't return any value. -* `int`, `float`, etc.: Denotes the data type of the value the function returns. - -Next, provide the function name with arguments (parameters) in the parameter list, or leave it empty if not required. Here's an example: - -```c++ -int add(int a, int b) -``` - -Now, define the body of the function, which specifies the specific task you want the function to perform. - -**Advantages of Functions:** - -* **Reduced Redundancy:** Functions minimize code redundancy by allowing you to write a block of code once and reuse it throughout your program. -* **Improved Readability:** Functions enhance code readability by breaking down complex logic into smaller, more manageable units. -* **Enhanced Maintainability:** Functions improve code maintainability by encapsulating specific functionalities, making it easier to modify or debug specific sections. -* **Promotes Reusability:** Functions promote code reusability by allowing you to utilize the same function in different parts of your program or even across multiple projects. - -**Standard Practices:** - -* A function can take parameters or not. -* It can be defined inside a class or outside. -* It can use global variables, local variables, parameters, or nothing at all. -* It can return a value or not (void type). - -**Function Examples:** - -Here are some more examples of functions: - -```c++ -// Factorial function -int factorial(int n) { - if (n == 0 || n == 1) { - return 1; - } else { - return n * factorial(n - 1); - } -} - -// Function with parameters -int multiply(int a, int b) { - return a * b; -} - -// Function with return value -int sum(int x, int y) { - return x + y; -} -``` - -**C++ Function with Default Arguments:** - -A default argument is a value assigned to a parameter in the function declaration. If no value is provided during the function call, the default value is automatically used. Here's an example: - -```c++ -int sum(int x, int y, int z = 0, int w = 0) { - return (x + y + z + w); -} -``` - -**C++ Function with Function Overloading:** - -Function overloading allows you to define multiple functions with the same name but different parameter lists. The compiler chooses the appropriate function based on the number and types of arguments passed during the call. Here's an example: - -```c++ -int add(int a, int b) { - return a + b; -} - -float add(float a, float b) { - return a + b; -} -``` - -**C++ Function with Recursion:** - -Recursion is a technique where a function calls itself. This is useful for breaking down complex problems into smaller, self-similar subproblems. Here's an example of a recursive function to calculate factorial: - -```c++ -int factorial(int n) { - if (n == 0 || n == 1) { - return 1; - } else { - return n * factorial(n - 1); - } -} -``` diff --git a/docs/day-07/switch-case-statement.md b/docs/day-07/switch-case-statement.md deleted file mode 100644 index df998a244..000000000 --- a/docs/day-07/switch-case-statement.md +++ /dev/null @@ -1,119 +0,0 @@ ---- -sidebar_position: 1 -title: "Switch Case Statement in C++" -description: "In this tutorial, we will learn about the switch case statement in C++ programming with the help of examples. The switch case statement is used to execute one statement from multiple conditions." -sidebar_label: "Switch Case Statement" -slug: switch-case-statement-in-cpp ---- - - - -### 1. What is the Switch Case Statement in C++? -The switch case statement in C++ is a control structure used to handle multiple selections by passing control to one of the case statements within its body. It is a more efficient alternative to using multiple if-else-if statements when you need to compare a variable to several constant values. - - -### 2. Explain the Syntax of Switch Case Statement in C++. -The basic syntax of a switch case statement in C++ is as follows: - -```cpp -switch (expression) { - case constant1: - // code to be executed if expression equals constant1; - break; - case constant2: - // code to be executed if expression equals constant2; - break; - ... - default: - // code to be executed if expression does not match any constant; -} -``` -- expression: This is the variable or value being compared. -- case constant: These are the values that expression is compared against. If a match is found, the corresponding block of code is executed. -- break: This statement terminates the switch case block. If omitted, execution will fall through to the next case. -- default: This is an optional case that runs if no other cases match. It's similar to the else in an if-else-if ladder. - -### 3. How does the Switch Case Statement work in C++? -The switch case statement evaluates the expression inside the switch and compares it with the constants of each case. When it finds a matching case, it executes the associated code block. If the break statement is encountered, the switch case block is terminated, and control is passed to the next line of code after the switch block. If no match is found, and a default case is provided, the code in the default block is executed. - -![Switch in CPP](../../static/img/day-07/switch-case.png) - -### 4. C++ Switch Case Statement Example -Here is a simple example of using a switch case statement in C++: - -```cpp -#include <iostream> -using namespace std; - -int main() { - int day = 4; - - switch (day) { - case 1: - cout << "Monday"; - break; - case 2: - cout << "Tuesday"; - break; - case 3: - cout << "Wednesday"; - break; - case 4: - cout << "Thursday"; - break; - case 5: - cout << "Friday"; - break; - case 6: - cout << "Saturday"; - break; - case 7: - cout << "Sunday"; - break; - default: - cout << "Invalid day"; - } - - return 0; -} -``` -In this example, the output will be: -``` -Thursday -``` -### 5. C++ Switch Case Statement with Break -The break statement is crucial in a switch case to prevent the fall-through behavior, where execution continues to the next case even after a match is found. Here’s an example demonstrating its importance: -```cpp -#include <iostream> -using namespace std; - -int main() { - int number = 2; - - switch (number) { - case 1: - cout << "Number is 1"; - break; - case 2: - cout << "Number is 2"; - // No break statement here - case 3: - cout << " or maybe 3"; - break; - default: - cout << "Number is not 1, 2, or 3"; - } - - return 0; -} -``` -In this example, the output will be: - -``` -Number is 2 or maybe 3 -``` -Without the break statement after case 2, the code "falls through" to case 3, and both case messages are printed. - -Using break statements appropriately ensures that only the matching case's code is executed, preventing unexpected behavior. - - diff --git a/docs/day-07/ternary-operator.md b/docs/day-07/ternary-operator.md deleted file mode 100644 index af2afd56a..000000000 --- a/docs/day-07/ternary-operator.md +++ /dev/null @@ -1,106 +0,0 @@ ---- -sidebar_position: 2 -title: "Ternary Operator in C++" -description: "In this tutorial, we will learn about the ternary operator in C++ programming with the help of examples. The ternary operator is a conditional operator that returns a value based on the condition." -sidebar_label: "Ternary Operator" -slug: ternary-operator-in-cpp ---- - - -## What is the Ternary Operator in C++? -In C++, the ternary operator, also known as **conditional operator**, is a shorthand way of writing conditional (if-else) statements. It is known as ternary operator because it takes **three** operands. This operator can be used to replace simple multi-line if-else statements with a single line of code. - - - -![Ternary in CPP](../../static/img/day-07/ternary-operator.png) - -## Syntax of Ternary Operator in C++ -The ternary/conditional operator `(? :)` takes 3 operands (`condition`, `expression_1` and `expression_2`). The basic syntax of ternary operator is: -```cpp -condition ? expression_1 : expression_2; -``` -The above statement, if written using `if-else`, is the same as: -```cpp -if(condition){ - expression_1; -} -else{ - expression_2; -} -``` - -## How does the Ternary Operator work in C++? -The ternary operator works by first evaluating the condition. If the condition evaluates to `true`, then the code corresponding to `expression_1` is executed. If the condition evaluates to `false`, then code corresponding to `expression_2` is executed. - -## C++ Ternary Operator Examples -### 1. Print the max of two integers -The following program takes two integers as input and prints maximum of them. - -```cpp -#include<iostream> -using namespace std; - -int main(){ - int a, b; - cout<<"Enter two numbers: "; - cin>>a>>b; - int maxi = (a > b) ? a : b; - cout<<"Max number is "<<maxi<<endl; - return(0); -} -``` -If condition `a>b` evaluates to `true`, then `maxi` stores the larger value `a`. If condition `a>b` evaluates to `false`, then `maxi` stores the value of `b`. - -### 2. Get absolute value of an integer -The function `get_abs` takes an integer as input and returns the absolute value of integer. The function shows the use of `return` with ternary operator. - -```cpp -#include <iostream> -using namespace std; - -int get_abs(int n){ - return (n>=0 ? n : -n); -} - -int main() -{ - int n; - cout << "Enter a number: "; - cin >> n; - cout << "Absolute value is " << get_abs(n) << endl; - return (0); -} -``` - -`` -NOTE: -`` -The following syntax for the function is **incorrect**: -```cpp -int get_abs(int n){ - n>=0 ? return(n) : return(-n); -} -// This is because return is a statement -// whereas ternary operator requires operands -// to be expression and not statement. -``` - -## C++ Ternary Operator with Nested Ternary Operator -The following program takes three integers as input and prints maximum of them. -```cpp -#include<iostream> -using namespace std; - -int main(){ - int a, b, c; - cout<<"Enter three numbers: "; - cin>>a>>b>>c; - int maxi = (a > b) ? ((a > c) ? a : c) : ((b>c) ? b : c); - cout<<"Max number is "<<maxi<<endl; - return(0); -} -``` - -If condition `a>b` evaluates to `true`, then we check the condition `a>c`. If `a>c` evaluates to `true`, then `maxi` stores the value of `a`, else `maxi` stores the value of `c`. - - If condition `a>b` evaluates to `false`, then we check the condition `b>c`. If `b>c` evaluates to `true`, then `maxi` stores the value of `b`, else `maxi` stores the value of `c`. \ No newline at end of file diff --git a/docs/day-08/_category_.json b/docs/day-08/_category_.json deleted file mode 100644 index f5e549cad..000000000 --- a/docs/day-08/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 08", - "position": 9, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-08/default-argument.md b/docs/day-08/default-argument.md deleted file mode 100644 index 96ce0c949..000000000 --- a/docs/day-08/default-argument.md +++ /dev/null @@ -1,60 +0,0 @@ ---- -sidebar_position: 1 -title: "Default Arguments in C++" -description: "In this tutorial, we will learn about Default Arguments in C++ programming with the help of examples. A default argument is a value provided in a function declaration that is automatically assigned by the compiler if the caller of the function does not provide a value for the argument." -sidebar_label: "Default Arguments" -slug: default-arguments-in-cpp ---- - - -### What is Default Arguments in C++? -Default arguments in C++ allow you to initialize a function parameter with a default value. This means that if the caller of the function doesn't provide a value for that parameter, the default value will be used. Default arguments provide flexibility and convenience in function calls by allowing some parameters to be optional. - - -![Switch in CPP](../../static/img/day-08/default-argument.png) - - -### Explain the Syntax of Default Arguments in C++. - -```cpp - -return_type function_name(type1 parameter1 = default_value1, type2 parameter2 = default_value2, ...); - -``` -Here, return_type is the type of value the function returns, function_name is the name of the function, type1, type2, etc., are the types of the function parameters, parameter1, parameter2, etc., are the names of the parameters, and default_value1, default_value2, etc., are the default values assigned to the parameters. - - -### How to Declare and Define a Function with Default Arguments in C++? - -```cpp - -#include <iostream> -using namespace std; - -void printMessage(string message = "Hello, World!") { - cout << message << endl; -} - -``` -In this example, the function printMessage is declared with a default argument message set to "Hello, World!". If no argument is provided when calling this function, it will print "Hello, World!". - -### C++ Default Arguments Example. - -```cpp - -#include <iostream> -using namespace std; - -void printNumber(int num, int width = 10) { - cout.width(width); - cout << num << endl; -} - -int main() { - printNumber(123); // Output: " 123" - printNumber(456, 5); // Output: " 456" - - return 0; -} - -``` diff --git a/docs/day-08/function-overloading.md b/docs/day-08/function-overloading.md deleted file mode 100644 index 261f131f7..000000000 --- a/docs/day-08/function-overloading.md +++ /dev/null @@ -1,363 +0,0 @@ ---- -sidebar_position: 2 -title: "Function Overloading in C++" -description: "In this tutorial, we will learn about Function Overloading in C++ programming with the help of examples. Function overloading is a feature in C++ where two or more functions can have the same name but different parameters." -sidebar_label: "Function Overloading" -slug: function-overloading-in-cpp ---- - -## 1. What is Function Overloading in C++? -Function overloading is a feature in C++ that allows you to define multiple functions with the same name, but with different parameters. This can be useful for creating functions that perform similar tasks, but with different inputs. - -## 2. Explain the Syntax of Function Overloading in C++ -To overload a function, you simply need to declare multiple functions with the same name, but with different parameter lists. The compiler will then choose the correct function to call based on the types of the arguments that you pass to it. -Here is an example of function overloading in C++: - -## Function Overloading in C++ -Function overloading in C++ is a feature that allows you to define multiple functions with the same name but with different parameter lists within the same scope. The parameter lists can differ in the number of parameters, the types of parameters, or both. The compiler determines which function to call based on the arguments used when the function is invoked. - -Here are the key points about function overloading: - -1. Same Function Name: All the overloaded functions must have the same name. -2. Different Parameter Lists: The functions must differ in the number and/or type of their parameters. This difference in the parameter list is known as the function's signature. -3. Return Type: The return type of the functions can be different, but the return type alone is not enough to distinguish overloaded functions. - -## Syntax of Function Overloading in C++ -The syntax of function overloading in C++ involves defining multiple functions with the same name but different parameter lists within the same scope. Here’s how you can do it, along with explanations and examples: - -### Basic Syntax - -1. **Function Declarations/Definitions**: - ```cpp - return_type function_name(parameter_list); - return_type function_name(parameter_list); - ``` - - - **return_type**: The return type of the function (e.g., `int`, `void`, `double`). - - **function_name**: The name of the function. - - **parameter_list**: A list of parameters that differ between overloaded functions. - -2. **Function Calls**: - ```cpp - function_name(arguments); - ``` - - ## How to Declare and Define a Function Overloading in C++ - Declaring and defining function overloading in C++ involves creating multiple functions with the same name but different parameter lists within the same scope. Here’s a step-by-step guide on how to declare and define overloaded functions. - -### Declaration of Overloaded Functions - -Function declarations, also known as function prototypes, provide the compiler with information about the function's name, return type, and parameters without giving the function's actual body. - -1. **Function Declaration Syntax**: - ```cpp - return_type function_name(parameter_list); - ``` - -2. **Example of Declarations**: - ```cpp - int add(int a, int b); // Declaration 1 - double add(double a, double b); // Declaration 2 - int add(int a, int b, int c); // Declaration 3 - ``` - -### Definition of Overloaded Functions - -Function definitions provide the actual body of the function. - -1. **Function Definition Syntax**: - ```cpp - return_type function_name(parameter_list) { - // Function body - } - ``` - -2. **Example of Definitions**: - ```cpp - int add(int a, int b) { - return a + b; - } - - double add(double a, double b) { - return a + b; - } - - int add(int a, int b, int c) { - return a + b + c; - } - ``` - -### Complete Example with Declarations and Definitions - -```cpp -#include <iostream> -using namespace std; - -// Declarations -int add(int a, int b); -double add(double a, double b); -int add(int a, int b, int c); - -int main() { - // Calling overloaded functions - cout << "Sum of 2 and 3: " << add(2, 3) << endl; // Calls add(int, int) - cout << "Sum of 2.5 and 3.5: " << add(2.5, 3.5) << endl; // Calls add(double, double) - cout << "Sum of 1, 2, and 3: " << add(1, 2, 3) << endl; // Calls add(int, int, int) - return 0; -} - -// Definitions -int add(int a, int b) { - return a + b; -} - -double add(double a, double b) { - return a + b; -} - -int add(int a, int b, int c) { - return a + b + c; -} -``` - -### Explanation - -1. **Declarations**: - - The function prototypes for `add` are declared before `main()`. - - These prototypes inform the compiler about the existence of these functions and their signatures. - -2. **Definitions**: - - The actual function bodies are defined after `main()`. - - Each overloaded function performs addition, but they differ in their parameter lists. - -3. **Function Calls in `main()`**: - - `add(2, 3)` calls the first `add` function (`int add(int, int)`). - - `add(2.5, 3.5)` calls the second `add` function (`double add(double, double)`). - - `add(1, 2, 3)` calls the third `add` function (`int add(int, int, int)`). - -### Summary - -To declare and define overloaded functions in C++, you: - -1. **Declare** the functions with the same name but different parameter lists. -2. **Define** each function with the same name but different parameter lists. -3. **Call** the appropriate overloaded function based on the arguments provided. - -This approach allows you to use the same function name for different tasks based on different input parameters, enhancing code readability and maintainability. - -## C++ Function Overloading Example -This example shows how to use function overloading to create multiple functions with the same name but different parameter lists, enhancing code readability and functionality. - -### Example: Area Calculation - -We will overload a function named `area` to calculate the area of different shapes: a rectangle, a circle, and a triangle. - -### Code Example - -```cpp -#include <iostream> -#include <cmath> // For M_PI and sqrt -using namespace std; - -// Function to calculate the area of a rectangle -double area(double length, double width) { - return length * width; -} - -// Function to calculate the area of a circle -double area(double radius) { - return M_PI * radius * radius; -} - -// Function to calculate the area of a triangle using Heron's formula -double area(double side1, double side2, double side3) { - double s = (side1 + side2 + side3) / 2; // Semi-perimeter - return sqrt(s * (s - side1) * (s - side2) * (s - side3)); -} - -int main() { - double length = 5.0, width = 3.0; - double radius = 4.0; - double side1 = 3.0, side2 = 4.0, side3 = 5.0; - - cout << "Area of rectangle: " << area(length, width) << endl; - cout << "Area of circle: " << area(radius) << endl; - cout << "Area of triangle: " << area(side1, side2, side3) << endl; - - return 0; -} -``` - -### Explanation - -1. **Function to Calculate the Area of a Rectangle**: - ```cpp - double area(double length, double width) { - return length * width; - } - ``` - - This function takes two parameters: `length` and `width`. - - It returns the area of the rectangle using the formula \( \text{area} = \text{length} \times \text{width} \). - -2. **Function to Calculate the Area of a Circle**: - ```cpp - double area(double radius) { - return M_PI * radius * radius; - } - ``` - - This function takes one parameter: `radius`. - - It returns the area of the circle using the formula \( \text{area} = \pi \times \text{radius}^2 \). - - `M_PI` is a constant representing the value of π (pi). - -3. **Function to Calculate the Area of a Triangle Using Heron's Formula**: - ```cpp - double area(double side1, double side2, double side3) { - double s = (side1 + side2 + side3) / 2; // Semi-perimeter - return sqrt(s * (s - side1) * (s - side2) * (s - side3)); - } - ``` - - This function takes three parameters: `side1`, `side2`, and `side3`. - - It calculates the area of the triangle using Heron's formula: - - First, it computes the semi-perimeter \( s \). - - Then, it calculates the area using the formula \( \text{area} = \sqrt{s \times (s - \text{side1}) \times (s - \text{side2}) \times (s - \text{side3})} \). - -4. **Main Function**: - ```cpp - int main() { - double length = 5.0, width = 3.0; - double radius = 4.0; - double side1 = 3.0, side2 = 4.0, side3 = 5.0; - - cout << "Area of rectangle: " << area(length, width) << endl; - cout << "Area of circle: " << area(radius) << endl; - cout << "Area of triangle: " << area(side1, side2, side3) << endl; - - return 0; - } - ``` - - The `main` function initializes the dimensions of different shapes. - - It calls the overloaded `area` functions with appropriate arguments for each shape. - - It prints the calculated areas of the rectangle, circle, and triangle. - -### Output - -The program will output the calculated areas for the rectangle, circle, and triangle: - -``` -Area of rectangle: 15 -Area of circle: 50.2655 -Area of triangle: 6 -``` - -This example demonstrates how function overloading can be used to create multiple functions with the same name but different parameter lists, allowing you to perform similar operations on different types or numbers of inputs. - -### Summary - -Function overloading in C++ allows multiple functions with the same name but different parameter lists. This enhances code readability and usability by enabling functions to perform similar tasks with different types or numbers of inputs. The compiler uses the function signature (name + parameter list) to determine which function to call. - -```cpp -int add(int a, int b) { - return a + b; -} - -float add(float a, float b) { - return a + b; -} - -string add(string a, string b) { - return a + b; -} -``` - -IMAGE FILE: -![Ternary in CPP](../../static/img/day-08/function-overloading.png) - -## 3. How to Declare and Define a Function Overloading in C++? - -To declare a function overload, you simply need to define two or more functions with the same name, but with different parameter lists. The compiler will then choose the appropriate function to call based on the types of arguments that are passed in. -For example, the following code shows two overloaded functions named add(): - -```cpp -int add(int x, int y) { - return x + y; -} - -double add(double x, double y) { - return x + y; -} -``` - -The first add() function takes two integer arguments and returns an integer. The second add() function takes two double arguments and returns a double. -When you call the add() function, the compiler will choose the appropriate function to call based on the types of arguments that you pass in. For example, the following code will call the first add() function: - -```cpp -int sum = add(1, 2); -``` - -The following code will call the second add() function: - -```cpp -double sum = add(1.5, 2.5); -``` - -Function overloading can be a very useful feature, but it is important to use it carefully. If you are not careful, you can easily create situations where the compiler is unable to determine which function to call. This can lead to errors in your code. - -## 4. C++ Function Overloading Example - -```cpp -#include <iostream> -using namespace std; - -// Prototype three print functions. -int print(std::string s); // Print a string. -int print(double dvalue); // Print a double. -int print(double dvalue, int prec); // Print a double with a -// given precision. - -int main(int argc, char *argv[]) { - const double d = 893094.2987; - - if (argc < 2) { - // These calls to print invoke print( char *s ). - print("This is a string."); - print(d); - } else { - // These calls to print invoke print( double dvalue, int prec ). - print(d, 2); - print(d, 5); - } - - return 0; -} - -// Define the three print functions. -int print(std::string s) { - std::cout << s << std::endl; - return 0; -} - -int print(double dvalue) { - std::cout << dvalue << std::endl; - return 0; -} - -int print(double dvalue, int prec) { - std::cout.precision(prec); - std::cout << fixed; - std::cout << dvalue << std::endl; - return 0; -} -``` - -This program defines three functions named print(). The first print() function takes a string argument and prints it to the console. The second print() function takes a double argument and prints it to the console. The third print() function takes two arguments: a double and an integer. The integer argument specifies the precision to which the double should be printed. - -The main() function calls the print() functions with different arguments. The first two calls to print() invoke the first print() function, which prints a string and a double to the console, respectively. The last two calls to print() invoke the third print() function, which prints the double argument with the specified precision. - -Here is the output of the program: - -```cpp -This is a string. -893094.2987 -893094.2987 -893094.29870 -``` \ No newline at end of file diff --git a/docs/day-08/inline-function.md b/docs/day-08/inline-function.md deleted file mode 100644 index 583a31aba..000000000 --- a/docs/day-08/inline-function.md +++ /dev/null @@ -1,60 +0,0 @@ ---- -sidebar_position: 3 -title: "Inline Function in C++" -description: "In this tutorial, we will learn about Inline Function in C++ programming with the help of examples. An inline function is a function that is expanded in line when it is called. When the inline function is called, the compiler replaces the function call with the corresponding function code." -sidebar_label: "Inline Function" -slug: inline-function-in-cpp ---- - - -### What is Inline Function in C++? -An inline function in C++ is a function that is expanded in place at each point in the code where it is called, instead of being called like a regular function. The compiler replaces the function call with the actual code of the function. Inline functions are typically used for small, frequently called functions, where the overhead of a function call would be significant. - - -![Function in CPP](../../static/img/day-08/inline-function.png) - - -### Explain the Syntax of Inline Function in C++. -```cpp - -inline return_type function_name(parameters) { - // Function body -} - -``` -Here, inline is the keyword indicating that the function is inline, return_type is the type of value the function returns, function_name is the name of the function, and parameters are the input parameters to the function. - - -### How to Declare and Define an Inline Function in C++? -You can declare and define an inline function in the same way you declare and define a regular function, but with the inline keyword added: - -```cpp -inline int add(int a, int b) { - return a + b; -} - -``` - -This declares and defines an inline function add that takes two int parameters and returns their sum. - - -### C++ Inline Function Example. -```cpp -#include <iostream> -using namespace std; - -// Inline function to calculate the square of a number -inline int square(int x) { - return x * x; -} - -int main() { - int num = 5; - - // Calling the inline function - cout << "Square of " << num << " is: " << square(num) << endl; - - return 0; -} - -``` diff --git a/docs/day-09/_category_.json b/docs/day-09/_category_.json deleted file mode 100644 index dc1940c8f..000000000 --- a/docs/day-09/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 09", - "position": 10, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-09/array-in-cpp.md b/docs/day-09/array-in-cpp.md deleted file mode 100644 index c7d3a9552..000000000 --- a/docs/day-09/array-in-cpp.md +++ /dev/null @@ -1,531 +0,0 @@ ---- -sidebar_position: 2 -title: "Array in C++" -description: "In this tutorial, we will learn about Arrays in C++ programming with the help of examples. An array is a collection of elements of the same data type that are stored in contiguous memory locations. Arrays are used to store multiple values in a single variable." -sidebar_label: "Array" -slug: array-in-cpp ---- - -TASK: - -1. What is an Array in C++? -2. Explain the Syntax of an Array in C++. -3. How to Declare and Define an Array in C++? -4. C++ Array Example -5. How to Access Elements of an Array in C++? -6. How to Update Elements of an Array in C++? -7. How to Calculate the Size of an Array in C++? -8. How to Traverse an Array in C++? -9. How to Pass an Array to a Function in C++? -10. How to Return an Array from a Function in C++? - - -### SOlution: -## What is an Array in C++? -In C++, an array is a data structure that can store a fixed-size sequential collection of elements of the same type. An array is used to store a collection of data, but it is often more useful to think of an array as a collection of variables of the same type. - -## Explain the syntax of an Array in C++? -The syntax of an array in C++ involves the declaration, initialization, and accessing of array elements. Here are the key aspects of array syntax in C++: - -1. Declaration: -To declare an array in C++, you specify the type of its elements, its name, and its size in square brackets. The general syntax is: - -```cpp -type arrayName[arraySize]; -``` - -- type: The data type of the elements in the array (e.g., int, float, double, char). -- arrayName: The name of the array. -- arraySize: The number of elements the array can hold. This must be a constant expression. - -```cpp -int numbers[10]; // declares an array of 10 integers -``` - -2. Initialization: -You can initialize an array at the time of declaration. This can be done in two ways: - -a. Initializing All Elements: -```cpp -type arrayName[arraySize] = {value1, value2, ..., valueN}; -``` -- value1, value2, ..., valueN: Initial values for the elements in the array. The number of values should not exceed arraySize. - -Example: -```cpp -int numbers[5] = {1, 2, 3, 4, 5}; // declares and initializes an array of 5 integers -``` - -b. Implicit Size Determination: -If the size of the array is omitted, the compiler determines the size based on the number of initializers. -```cpp -type arrayName[] = {value1, value2, ..., valueN}; -``` - -Example: -```cpp -int numbers[] = {1, 2, 3, 4, 5}; // size is automatically determined to be 5 -``` - -3. Accessing Elements: -Array elements are accessed using the index operator []. The index of the first element is 0. -```cpp -arrayName[index] -``` -- index: The position of the element in the array (starting from 0). - -Example: -```cpp -int firstElement = numbers[0]; // accesses the first element (1) -numbers[2] = 10; // sets the third element to 10 -``` - -4. Multi-dimensional Arrays: -C++ supports multi-dimensional arrays. The syntax for a two-dimensional array is: - -```cpp -type arrayName[size1][size2]; -``` - -### How to Declare and Define an Array in C++? -To declare and define an array in C++, you specify the type of its elements, its name, and its size. You can also initialize the array at the time of declaration. - -Declaration: -To declare an array, use the following syntax: -```cpp -type arrayName[arraySize]; -``` - -- type: The data type of the array elements (e.g., int, float, double, char). -- arrayName: The name of the array. -- arraySize: The number of elements the array can hold. - -Definition with Initialization: -You can define and initialize an array at the same time: - -With Explicit Size: -```cpp -type arrayName[arraySize] = {value1, value2, ..., valueN}; -``` - -With Implicit Size: -If you omit the size, the compiler determines it based on the number of initializers: -```cpp -type arrayName[] = {value1, value2, ..., valueN}; -``` - -## C++ Array Example - -- One-Dimensional Array Example - This example demonstrates how to declare, initialize, and access elements of a one-dimensional array. - ```cpp - #include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a one-dimensional array - int numbers[5] = {10, 20, 30, 40, 50}; - - // Printing all elements of the array - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << numbers[i] << endl; - } - - // Modifying an element - numbers[2] = 35; // Change the third element from 30 to 35 - - // Printing the modified array - cout << "Modified array:" << endl; - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << numbers[i] << endl; - } - - return 0; -} -``` - -- Two-Dimensional Array Example - This example demonstrates how to declare, initialize, and access elements of a two-dimensional array. - -```cpp - #include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a two-dimensional array - int matrix[2][3] = { - {1, 2, 3}, - {4, 5, 6} - }; - - // Printing all elements of the 2D array - for (int i = 0; i < 2; i++) { - for (int j = 0; j < 3; j++) { - cout << "Element at (" << i << ", " << j << "): " << matrix[i][j] << endl; - } - } - - // Modifying an element - matrix[1][2] = 10; // Change the element at row 1, column 2 from 6 to 10 - - // Printing the modified 2D array - cout << "Modified 2D array:" << endl; - for (int i = 0; i < 2; i++) { - for (int j = 0; j < 3; j++) { - cout << "Element at (" << i << ", " << j << "): " << matrix[i][j] << endl; - } - } - - return 0; -} -``` - -## How to Access Elements of an Array in C++? - -To access elements of an array in C++, you use the array name followed by the index of the element enclosed in square brackets ([]). The index is zero-based, meaning the first element has an index of 0, the second element has an index of 1, and so on. - -Syntax for Accessing Elements -```cpp -arrayName[index] -``` - -Example: One-Dimensional Array -Here is an example demonstrating how to access and manipulate elements of a one-dimensional array: - -```cpp -#include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a one-dimensional array - int numbers[5] = {10, 20, 30, 40, 50}; - - // Accessing and printing elements of the array - cout << "First element: " << numbers[0] << endl; // Accessing the first element - cout << "Second element: " << numbers[1] << endl; // Accessing the second element - - // Modifying elements of the array - numbers[2] = 35; // Modifying the third element - numbers[4] = 55; // Modifying the fifth element - - // Printing all elements of the array after modification - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << numbers[i] << endl; - } - - return 0; -} -``` - -Example: Two-Dimensional Array -Here is an example demonstrating how to access and manipulate elements of a two-dimensional array: -```cpp -#include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a two-dimensional array - int matrix[2][3] = { - {1, 2, 3}, - {4, 5, 6} - }; - - // Accessing and printing elements of the 2D array - cout << "Element at (0, 0): " << matrix[0][0] << endl; // Accessing the element at row 0, column 0 - cout << "Element at (1, 2): " << matrix[1][2] << endl; // Accessing the element at row 1, column 2 - - // Modifying elements of the 2D array - matrix[0][1] = 20; // Modifying the element at row 0, column 1 - matrix[1][2] = 60; // Modifying the element at row 1, column 2 - - // Printing all elements of the 2D array after modification - for (int i = 0; i < 2; i++) { - for (int j = 0; j < 3; j++) { - cout << "Element at (" << i << ", " << j << "): " << matrix[i][j] << endl; - } - } - - return 0; -} -``` - -## How to Update Elements of an Array in C++? -Updating elements of an array in C++ involves accessing the element using its index and then assigning a new value to it. This can be done using the assignment operator (=). Below are the steps and examples for updating elements in both one-dimensional and two-dimensional arrays. - -Syntax for Updating Elements -```cpp -arrayName[index] = newValue; -``` - -Example: Updating a One-Dimensional Array -Here's an example that demonstrates how to update elements in a one-dimensional array: -```cpp -#include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a one-dimensional array - int numbers[5] = {10, 20, 30, 40, 50}; - - // Printing the original array - cout << "Original array:" << endl; - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << numbers[i] << endl; - } - - // Updating elements of the array - numbers[0] = 15; // Update the first element to 15 - numbers[3] = 45; // Update the fourth element to 45 - - // Printing the updated array - cout << "Updated array:" << endl; - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << numbers[i] << endl; - } - - return 0; -} -``` - -Example: Updating a Two-Dimensional Array -Here's an example that demonstrates how to update elements in a two-dimensional array: -```cpp -#include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a two-dimensional array - int matrix[2][3] = { - {1, 2, 3}, - {4, 5, 6} - }; - - // Printing the original 2D array - cout << "Original 2D array:" << endl; - for (int i = 0; i < 2; i++) { - for (int j = 0; j < 3; j++) { - cout << "Element at (" << i << ", " << j << "): " << matrix[i][j] << endl; - } - } - - // Updating elements of the 2D array - matrix[0][1] = 20; // Update the element at row 0, column 1 to 20 - matrix[1][2] = 60; // Update the element at row 1, column 2 to 60 - - // Printing the updated 2D array - cout << "Updated 2D array:" << endl; - for (int i = 0; i < 2; i++) { - for (int j = 0; j < 3; j++) { - cout << "Element at (" << i << ", " << j << "): " << matrix[i][j] << endl; - } - } - - return 0; -} -``` - -## How to Calculate the Size of an Array in C++? - -In C++, you can calculate the size of an array using the sizeof operator or by dividing the total size of the array by the size of an individual element. Here are two common methods: - -Using sizeof Operator -You can use the sizeof operator to determine the size of an array in bytes. Divide the total size of the array by the size of an individual element to get the number of elements in the array. Here's how you can do it: - -```cpp -#include <iostream> -using namespace std; - -int main() { - int numbers[5] = {1, 2, 3, 4, 5}; - - // Calculate the size of the array - int sizeOfArray = sizeof(numbers) / sizeof(numbers[0]); - - cout << "Size of the array: " << sizeOfArray << endl; - - return 0; -} -``` -Output: -```cpp -Size of the array: 5 -``` - -## How to Traverse an Array in C++? - -Traversing an array in C++ involves accessing each element of the array one by one. This is commonly done using a loop, such as a for loop. Here's how you can traverse an array: - -Example: Traversing a One-Dimensional Array -```cpp -#include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a one-dimensional array - int numbers[5] = {10, 20, 30, 40, 50}; - - // Traversing the array using a for loop - cout << "Traversing the one-dimensional array:" << endl; - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << numbers[i] << endl; - } - - return 0; -} -``` - -Output: -```cpp -Traversing the one-dimensional array: -Element at index 0: 10 -Element at index 1: 20 -Element at index 2: 30 -Element at index 3: 40 -Element at index 4: 50 -``` - -Example: Traversing a Two-Dimensional Array -```cpp -#include <iostream> -using namespace std; - -int main() { - // Declaration and initialization of a two-dimensional array - int matrix[2][3] = { - {1, 2, 3}, - {4, 5, 6} - }; - - // Traversing the array using nested for loops - cout << "Traversing the two-dimensional array:" << endl; - for (int i = 0; i < 2; i++) { - for (int j = 0; j < 3; j++) { - cout << "Element at (" << i << ", " << j << "): " << matrix[i][j] << endl; - } - } - - return 0; -} -``` - -Output: -```cpp -Traversing the two-dimensional array: -Element at (0, 0): 1 -Element at (0, 1): 2 -Element at (0, 2): 3 -Element at (1, 0): 4 -Element at (1, 1): 5 -Element at (1, 2): 6 -``` - -## How to Pass an Array to a Function in C++? - -In C++, you can pass an array to a function in two main ways: by passing the array name or by passing a pointer to the array. Here are both methods explained: - -Passing an Array to a Function Using Array Name -When you pass an array to a function using its name, you are actually passing a pointer to the first element of the array. Here's how you can do it: -```cpp -#include <iostream> -using namespace std; - -// Function to print elements of an array -void printArray(int arr[], int size) { - for (int i = 0; i < size; i++) { - cout << arr[i] << " "; - } - cout << endl; -} - -int main() { - int numbers[] = {1, 2, 3, 4, 5}; - - // Passing the array to the function - printArray(numbers, 5); - - return 0; -} -``` - -Output: -```cpp -1 2 3 4 5 -``` - -## How to Return an Array from a Function in C++? -In C++, you cannot directly return an entire array from a function. However, you can return a pointer to the array or use other data structures like std::vector or std::array to achieve similar functionality. Below are two common methods: - -Method 1: Returning a Pointer to the Array -```cpp -#include <iostream> -using namespace std; - -// Function to create and return an array -int* createArray(int size) { - int* arr = new int[size]; - for (int i = 0; i < size; ++i) { - arr[i] = i * 10; - } - return arr; -} - -int main() { - int size = 5; - int* myArray = createArray(size); - - // Printing the elements of the returned array - for (int i = 0; i < size; ++i) { - cout << myArray[i] << " "; - } - cout << endl; - - // Don't forget to delete the dynamically allocated array - delete[] myArray; - - return 0; -} -``` - -Output: -```cpp -0 10 20 30 40 -``` - -Method 2: Using std::vector -```cpp -#include <iostream> -#include <vector> -using namespace std; - -// Function to create and return a vector -vector<int> createArray(int size) { - vector<int> arr(size); - for (int i = 0; i < size; ++i) { - arr[i] = i * 10; - } - return arr; -} - -int main() { - int size = 5; - vector<int> myVector = createArray(size); - - // Printing the elements of the returned vector - for (int i = 0; i < size; ++i) { - cout << myVector[i] << " "; - } - cout << endl; - - return 0; -} -``` - -Output: -```cpp -0 10 20 30 40 -``` - - -IMAGE FILE: -![Ternary in CPP](../../static/img/day-09/array-in-cpp.png) - diff --git a/docs/day-09/array-in-function.md b/docs/day-09/array-in-function.md deleted file mode 100644 index 370d8ff88..000000000 --- a/docs/day-09/array-in-function.md +++ /dev/null @@ -1,184 +0,0 @@ ---- -sidebar_position: 3 -title: "Array in Function in C++" -description: "In this tutorial, we will learn about Arrays in Function in C++ programming with the help of examples. An array is a collection of elements of the same data type that are stored in contiguous memory locations. Arrays are used to store multiple values in a single variable." -sidebar_label: "Array in Function" -slug: array-in-function-in-cpp ---- - - -## Arrays in C++ Functions - -![Function in CPP](../../static/img/day-09/array-in-function.png) - -### 1. What are Arrays in Functions? - -In C++, an array within a function is a collection of elements with the same data type, stored contiguously in memory. You can use arrays in functions in two ways: - -* **Passing arrays as arguments:** Allow functions to operate on the elements of an existing array. -* **Declaring arrays within functions:** Create temporary arrays for specific function tasks. - -### 2. Syntax of Arrays in Functions - -**Passing Arrays as Arguments:** - -There are three common methods: - -* **By pointer:** - ```c++ - void myFunction(int *myArray, int size); // Function parameter - ``` -* **By sized array (deprecated):** - ```c++ - void myFunction(int myArray[10]); // Function parameter (deprecated) - ``` -* **By reference (C++11 and later):** - ```c++ - void myFunction(const int (&myArray)[10]); // Function parameter (C++11+) - ``` - -**Declaring Arrays within Functions:** - -```c++ -void myFunction() { - int localArray[5]; // Array declared locally within the function -} -``` - -## 3. How to Declare and Define an Array in Function in C++? - -### Declaring an Array in Function - -When declaring an array in the function parameter list, you typically just declare it as a pointer, because arrays decay to pointers when passed to functions. - -```cpp -void printArray(int arr[], int size); -``` - -### Defining a Function that Accepts an Array - -Here's how you might define a function that takes an array as an argument: - -```cpp -void printArray(int arr[], int size) { - for (int i = 0; i < size; i++) { - std::cout << arr[i] << " "; - } - std::cout << std::endl; -} -``` - - -### 4. C++ Array in Function Example (Passing by Pointer) - -```c++ -#include <iostream> - -void printArray(int *arr, int size) { - for (int i = 0; i < size; i++) { - std::cout << arr[i] << " "; - } - std::cout << std::endl; -} - -int main() { - int myArray[] = {1, 2, 3, 4, 5}; - int n = sizeof(myArray) / sizeof(myArray[0]); // Get array size - printArray(myArray, n); // Pass array and its size - return 0; -} -``` - -This code defines a `printArray` function that takes an integer pointer and the array size as arguments. It then iterates through the array and prints its elements. - -## 5. How to Pass an Array to a Function in C++? - -To pass an array to a function in C++, you can simply specify the array name (which decays to a pointer) and optionally the size of the array. - -```cpp -#include <iostream> - -void processArray(int arr[], int size) { - // Process array elements - for (int i = 0; i < size; i++) { - arr[i] *= 2; // Example processing: double each element - } -} - -int main() { - int myArray[] = {1, 2, 3, 4, 5}; - int size = sizeof(myArray) / sizeof(myArray[0]); - processArray(myArray, size); - - // Print the processed array - for (int i = 0; i < size; i++) { - std::cout << myArray[i] << " "; - } - std::cout << std::endl; - return 0; -} -``` - -## 6. How to Return an Array from a Function in C++? - -In C++, you cannot return arrays directly from functions. Instead, you can return a pointer to an array, or use other data structures like `std::vector` or `std::array` from the C++ Standard Library, which are more flexible and safer. - -### Example using a pointer: - -```cpp -#include <iostream> - -int* createArray(int size) { - int* arr = new int[size]; - for (int i = 0; i < size; i++) { - arr[i] = i + 1; - } - return arr; -} - -int main() { - int size = 5; - int* myArray = createArray(size); - - for (int i = 0; i < size; i++) { - std::cout << myArray[i] << " "; - } - std::cout << std::endl; - - delete[] myArray; // Don't forget to free the allocated memory - return 0; -} -``` - -### Example using `std::vector`: - -```cpp -#include <iostream> -#include <vector> - -std::vector<int> createVector(int size) { - std::vector<int> vec(size); - for (int i = 0; i < size; i++) { - vec[i] = i + 1; - } - return vec; -} - -int main() { - int size = 5; - std::vector<int> myVector = createVector(size); - - for (int i = 0; i < size; i++) { - std::cout << myVector[i] << " "; - } - std::cout << std::endl; - return 0; -} -``` - -Using `std::vector` or `std::array` is generally preferred due to better safety, easier memory management, and more features compared to raw arrays. - - -**Note:** While sized arrays (like `void myFunction(int myArray[10])`) were used in the past, they are generally discouraged due to limitations and potential safety concerns. Prefer using pointers or references for better flexibility and clarity. - - diff --git a/docs/day-09/recursion-in-cpp.md b/docs/day-09/recursion-in-cpp.md deleted file mode 100644 index b23d4a50f..000000000 --- a/docs/day-09/recursion-in-cpp.md +++ /dev/null @@ -1,219 +0,0 @@ ---- -sidebar_position: 5 -title: "Recursion in C++" -description: "In this tutorial, we will learn about recursion in C++ with the help of examples. Recursion is a programming technique where a function calls itself to solve smaller instances of a problem." -sidebar_label: "Recursion" -slug: recursion-in-cpp ---- - - -## Recursion in C++? -Recursion in C++ is a technique in which a function calls itself repeatedly until a given condition is satisfied. It can be a powerful tool in programming, particularly for tasks that can be divided into smaller, similar sub-tasks. - -![Switch in CPP](../../static/img/day-09/recursion.png) - - -## Syntax -```cpp -return_type recursive_func { - .... - // Base Condition - // Recursive Case - .... -} -``` -A recursive function has a base condition that stops further calls by returning a result, and a recursive case that calls the function with smaller sub-problems until the base condition is met. - -## Recusive Function -A function that calls itself is called a recursive function. When a recursive function is called, it executes a set of instructions and then calls itself to execute the same set of instructions with a smaller input. - -## Why Use Recursion? - -Recursion is particularly useful for: -- Problems that can naturally be divided into similar sub-problems (e.g., factorial calculation, Fibonacci series). -- Implementing algorithms in a more readable and concise way (e.g., tree traversals, searching algorithms). - -## How Recursion Works - -A recursive function typically has two main components: -- **Base case**: A condition under which the function stops calling itself, preventing infinite recursion. -- **Recursive case**: The part of the function where the function calls itself with modified arguments. - -**Example Structure: - -```cpp -void recursiveFunction() { - if (baseCondition) { - // Base case - return; - } else { - // Recursive case - recursiveFunction(); - } -} -``` - -## How to Declare and Define a Recursive Function in C++? - -To declare and define a recursive function in C++, follow these steps: - -## Declaration : You need to declare the function prototype at the beginning of your code or before its first use if it’s being called in multiple functions. - -## Definition : You then define the function, specifying its behavior, including the base condition and the recursive case. - -## Example : -```cpp -#include <iostream> - -// Declaration -int factorial(int n); - -// Definition -int factorial(int n) { - if (n <= 1) { - return 1; - } else { - return n * factorial(n - 1); // recursive call - } -} - -int main() { - int number = 5; - std::cout << "Factorial of " << number << " is " << factorial(number) << std::endl; - return 0; -} -``` -## Output -```cpp - Factorial of 5 is 125. -``` -Here in this example we have performed the task to calculate a factorial of numbers. - -## Advantages of C++ Recursion -- It makes our code shorter and cleaner. -- Recursion is required in problems concerning data structures and advanced algorithms, such as Graph and Tree Traversal. - -## Disadvantages of C++ Recursion -- It takes a lot of stack space compared to an iterative program. -- It uses more processor time. -- It can be more difficult to debug compared to an equivalent iterative program. - -## Types of Recursion in C++ -There are two different types of recursion which are as follows: - -1. Direct Recursion -2. Indirect Recursion - -## 1. Direct Recursion -Direct recursion involves a function calling itself directly within its body. It can be further categorized into three types: - -a) Head Recursion: In head recursion, the recursive call is present at the start of the function. It is a kind of linear recursion where only a single recursive call is used. - -b) Tail Recursion: Tail recursion is a linear recursion where it’s one and only recursive call is present at the end of the function. - -c) Tree Recursion: In Tree Recursion, there are multiple recursive calls present in the body of the function. - -## 2. Indirect Recursion -In indirect recursion, the function does not call itself directly but instead, it calls another function which then eventually calls the first function creating a cycle of function calls. - -## Example : -```cpp - #include <iostream> -using namespace std; - -// Function for fibonacci -int fib(int n) -{ - // Stop condition - if (n == 0) - return 0; - // Stop condition - if (n == 1 || n == 2) - return 1; - // Recursion function - else - return (fib(n - 1) + fib(n - 2)); -} - -int main() -{ - // Initialize variable n. - int n = 5; - cout << "Fibonacci series of 5 numbers is: "; - // for loop to print the fibonacci series. - for (int i = 0; i < n; i++) { - cout << fib(i) << " "; - } - return 0; -} -``` -## Output -```cpp - Fibonacci series of 5 numbers is: 0 1 1 2 3 -``` - -## Applications of Recursion -Recursion has many applications in computer science and programming. Here are some of the most common applications of recursion: - -- Solving: Fibonacci sequences, Factorial Function, Reversing an array, Tower of Hanoi. -- Backtracking: It is a technique for solving problems by trying out different solutions and undoing them if they do not work. Recursive algorithms are often used in backtracking. -- Searching and Sorting Algorithms: Many searching and sorting algorithms, such as binary search and quicksort, use recursion to divide the problem into smaller - sub-problems. -- Tree and Graph Traversal: Recursive algorithms are often used to traverse trees and graphs, such as depth-first search and breadth-first search. -- Mathematical Computations: Recursion is also used in many mathematical computations, such as the factorial function and the Fibonacci sequence. -- Dynamic Programming: It is a technique for solving optimization problems by breaking them down into smaller sub-problems. Recursive algorithms are often used in dynamic programming. - -## Recursion Examples : - -Some more examples : - -## Example 1 : Reverse a String -```cpp -#include <iostream> - -void reverseString(std::string& str, int start, int end) { - if (start >= end) - return; - std::swap(str[start], str[end]); - reverseString(str, start + 1, end - 1); -} - -int main() { - std::string str = "Hello"; - reverseString(str, 0, str.length() - 1); - std::cout << "Reversed string is: " << str << std::endl; - return 0; -} - -``` -## Output -```cpp - Reversed string is: olleH -``` - -## Example 2 : Sum of Digits -```cpp -#include <iostream> -using namespace std; - -int sumOfDigits(int n) { - if (n == 0) // Base case - return 0; - return (n % 10) + sumOfDigits(n / 10); // Recursive case -} - -int main() { - int num = 12345; - cout << "Sum of digits of " << num << " is " << sumOfDigits(num) << endl; - return 0; -} - -``` -## Output -```cpp - Sum of digits of 12345 is 15. -``` -## Conclusion : - -Recursion is a fundamental concept in C++ that provides a straightforward way to solve problems by breaking them down into smaller sub-problems. Understanding how to use recursion effectively can greatly enhance your problem-solving skills and enable you to write cleaner, more efficient code. - - diff --git a/docs/day-10/_category_.json b/docs/day-10/_category_.json deleted file mode 100644 index fcb448061..000000000 --- a/docs/day-10/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 10", - "position": 11, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-10/multidimentional-array.md b/docs/day-10/multidimentional-array.md deleted file mode 100644 index e2ffc728f..000000000 --- a/docs/day-10/multidimentional-array.md +++ /dev/null @@ -1,76 +0,0 @@ ---- -sidebar_position: 1 -title: "Multi-Dimensional Array in C++" -description: "In this tutorial, we will learn about Multi-Dimensional Arrays in C++ programming with the help of examples. A multi-dimensional array is an array of arrays. In C++, we can create a two-dimensional array, three-dimensional array, and so on." -sidebar_label: "Multi-Dimensional Array" -slug: multi-dimensional-array-in-cpp ---- - -### What is a Multi-Dimensional Array in C++? -A multi-dimensional array in C++ is an array that holds elements in more than one dimension. Unlike a one-dimensional array, which is a list of elements accessed by a single index, a multi-dimensional array is accessed by multiple indices. Common examples include 2D arrays (matrices) and 3D arrays (cubes). - - -1. What is a Multi-Dimensional Array in C++? -2. Explain the Syntax of a Multi-Dimensional Array in C++. -3. How to Declare and Define a Multi-Dimensional Array in C++? -4. C++ Multi-Dimensional Array Example -5. How do you access an element in a two-dimensional array in C++? -6. How do you pass a two-dimensional array to a function in C++? -7. What is the syntax for looping through all elements of a two-dimensional array in C++? -8. What is the difference between a multidimensional array and an array of arrays in C++? -9. Can you dynamically allocate a two-dimensional array in C++? If so,how? -10. What are the advantages and disadvantages of using multidimensional arrays in C++? -11. How do you deallocate a dynamically allocated multidimensional array in C++? -12. What is the memory layout of a two-dimensional array in C++? -13. How do you use multidimensional array to represent matrices in C++? -14. What is the role of the std::vector in handling multidimensional arrays in C++? -15. How do multidimensional arrays interact with pointers in C++? - - -![Multidimentional-array](../../static/img/day-10/multidimentional-array.png) - - -### Explain the Syntax of a Multi-Dimensional Array in C++. -```cpp - -data_type array_name[size1][size2]...[sizeN]; - -``` - -Here, data_type is the type of elements the array will hold, array_name is the name of the array, and size1, size2, ..., sizeN are the sizes of each dimension of the array. - - -### How to Declare and Define a Multi-Dimensional Array in C++? -```cpp - -int arr[3][4]; // Declares a 2D array with 3 rows and 4 columns - -// Another way to declare and initialize a 2D array: -int arr2[2][3] = {{1, 2, 3}, {4, 5, 6}}; - -``` - -### C++ Multi-Dimensional Array Example. - -```cpp - -#include <iostream> -using namespace std; - -int main() { - int arr[3][3] = {{1, 2, 3}, {4, 5, 6}, {7, 8, 9}}; - - // Accessing elements of the array - cout << "Elements of the 2D array:" << endl; - for (int i = 0; i < 3; ++i) { - for (int j = 0; j < 3; ++j) { - cout << arr[i][j] << " "; - } - cout << endl; - } - - return 0; -} - -``` - diff --git a/docs/day-10/singledimensional-array.md b/docs/day-10/singledimensional-array.md deleted file mode 100644 index 3423b98b0..000000000 --- a/docs/day-10/singledimensional-array.md +++ /dev/null @@ -1,116 +0,0 @@ ---- -sidebar_position: 4 -title: "Single Dimensional Arrays in C++" -description: "In this tutorial, we will learn about single dimensional arrays in C++ with the help of examples. Arrays are used to store multiple values in a single variable." -sidebar_label: "Single Dimensional Arrays" -slug: single-dimensional-arrays-in-cpp ---- - -## 1. What is a Single Dimensional Array in C++? - -A single dimensional array is a collection of elements of the same data type, stored in contiguous memory locations. Arrays allow you to store multiple values in a single variable, which can be accessed using an index. - -![Single Dimensional Array in C++](../../static/img/day-10/singledimensional-array.png) - -## 2. Why Use Arrays? - -Arrays are used to: -- Store multiple values of the same type in a single variable. -- Easily access and manipulate a collection of data. -- Efficiently manage memory by storing elements in contiguous memory locations. - -## 3. Declaring and Initializing Arrays - -You can declare an array by specifying the data type, array name, and size. - -**Syntax:** - -```cpp -datatype arrayName[arraySize]; -``` - -You can also initialize an array at the time of declaration. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int numbers[5]; // Declaration - int scores[5] = {85, 90, 78, 92, 88}; // Declaration and Initialization - return 0; -} -``` - -## 4. Accessing Array Elements - -Array elements are accessed using their index. The index of the first element is 0, and the index of the last element is `arraySize - 1`. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int scores[5] = {85, 90, 78, 92, 88}; - cout << "First element: " << scores[0] << endl; // Output: 85 - cout << "Last element: " << scores[4] << endl; // Output: 88 - return 0; -} -``` - -## 5. Looping Through an Array - -You can use loops to iterate through array elements for processing. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int scores[5] = {85, 90, 78, 92, 88}; - for (int i = 0; i < 5; i++) { - cout << "Element at index " << i << ": " << scores[i] << endl; - } - return 0; -} -``` - -## 6. Modifying Array Elements - -You can modify the elements of an array by accessing them via their index. - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int scores[5] = {85, 90, 78, 92, 88}; - scores[2] = 80; // Modify the element at index 2 - cout << "Modified element at index 2: " << scores[2] << endl; // Output: 80 - return 0; -} -``` - -## 7. Advantages and Disadvantages of Arrays - -### Advantages -- **Efficient Data Management**: Arrays allow efficient management and manipulation of data. -- **Ease of Access**: Direct access to any element using its index. -- **Memory Management**: Efficient use of memory by storing elements in contiguous locations. - -### Disadvantages -- **Fixed Size**: The size of an array is fixed at compile time and cannot be changed during runtime. -- **Single Data Type**: Arrays can store elements of only one data type. -- **Memory Waste**: If the array size is larger than the required number of elements, memory can be wasted. - -## 8. Conclusion - -Single dimensional arrays are a fundamental data structure in C++, providing an efficient way to store and manage collections of data. Understanding arrays and their operations is crucial for solving various programming problems effectively. \ No newline at end of file diff --git a/docs/day-10/string-class.md b/docs/day-10/string-class.md deleted file mode 100644 index 87833049f..000000000 --- a/docs/day-10/string-class.md +++ /dev/null @@ -1,108 +0,0 @@ ---- -sidebar_position: 3 -title: "All About String Class" -description: "In this tutorial, we will learn about the String Class in C++ programming with the help of examples. A string is a sequence of characters that is used to represent text. In C++, strings are represented using the `std::string` class. The `std::string` class provides various member functions to manipulate strings." -sidebar_label: "String Class" -slug: string-class-in-cpp ---- - -### What is a String Class in C++? -In C++, a string class is a part of the Standard Template Library (STL) that provides a convenient way to work with strings of characters. It encapsulates various string operations and functionalities, making string manipulation easier for developers. - - -1. What is a String Class in C++? -2. Explain the Syntax of a String Class in C++. -3. How to Declare and Define a String Class in C++? -4. C++ String Class Example -5. How to Input and Output a String Class in C++? -6. How to Concatenate String Classes in C++? -7. what is the std::string class in C++? -8. How do you declare and initialize a std::string in C++? -9. How do you find the length of a std::string? -10. How do you compare two std::string objects in C++? - - -![Function in CPP](../../static/img/day-10/string-class.png) - -### Explain the Syntax of a String Class in C++. -The syntax for declaring a string object in C++ is: - -```cpp - -#include <string> - -std::string myString; - -``` -Here, std::string is the string class, and myString is an instance of the class. - -### How to Declare and Define a String Class in C++? -To declare and define a string class in C++, you can simply create an object of the std::string class. -## Here's how: -```cpp - -#include <string> - -std::string myString = "Hello, World!"; - -``` - -### C++ String Class Example. -Here's a basic example demonstrating the usage of the C++ string class: -```cpp - -#include <iostream> -#include <string> - -int main() { - std::string greeting = "Hello, "; - std::string name = "Tina"; - std::cout << greeting + name << std::endl; - return 0; -} - -``` - -### How to Input and Output a String Class in C++? -You can use the standard input/output operations to work with string classes in C++. -## Here's an example: - -```cpp - -#include <iostream> -#include <string> - -int main() { - std::string inputString; - std::cout << "Enter a string: "; - std::cin >> inputString; - std::cout << "You entered: " << inputString << std::endl; - return 0; -} - -``` - -### How to Concatenate String Classes in C++? -In C++, you can concatenate string classes using the + operator or the append() function. -## Examples of both methods: -```cpp - -#include <iostream> -#include <string> - -int main() { - std::string firstString = "Hello, "; - std::string secondString = "World!"; - - // Using the + operator - std::string result1 = firstString + secondString; - std::cout << "Concatenated string using + operator: " << result1 << std::endl; - - // Using the append() function - firstString.append(secondString); - std::cout << "Concatenated string using append(): " << firstString << std::endl; - - return 0; -} - -``` diff --git a/docs/day-10/string-in-cpp.md b/docs/day-10/string-in-cpp.md deleted file mode 100644 index 9206735c8..000000000 --- a/docs/day-10/string-in-cpp.md +++ /dev/null @@ -1,181 +0,0 @@ ---- -sidebar_position: 2 -title: "String in C++" -description: "In this tutorial, we will learn about Strings in C++ programming with the help of examples. A string is a sequence of characters that is used to represent text. In C++, strings are represented using the `std::string` class. The `std::string` class provides various member functions to manipulate strings." -sidebar_label: "String" -slug: string-in-cpp ---- - -### What is a String in C++? -In C++, a string is a sequence of characters stored in contiguous memory locations. It's a data type used to represent text rather than numerical values. - -### Explain the Syntax of a String in C++. -The syntax for declaring a string in C++ is -```cpp - -std::string myString; - -``` -Here, std::string is the data type for the string, and myString is the name of the string variable. - -![String in CPP](../../static/img/day-10/string-in-cpp.png) - - -### How to Declare and Define a String in C++? - -## Declaration -```cpp - -std::string myString; - -``` -## Defination -```cpp - -myString = "Hello, World!"; - -``` - -### C++ String Example - -```cpp - -#include <iostream> -#include <string> - -int main() { - std::string greeting = "Hello, World!"; - std::cout << greeting << std::endl; - return 0; -} - -``` - -### How to Input and Output a String in C++? - -## Input -```cpp - -std::string userInput; -std::cin >> userInput; - -``` -## Output -```cpp - -std::cout << userInput << std::endl; - -``` - -### How to Concatenate Strings in C++? -```cpp - -std::string str1 = "Hello"; -std::string str2 = "World"; -std::string result = str1 + str2; - -``` - -### How to Compare Strings in C++? - -```cpp - -std::string str1 = "Hello"; -std::string str2 = "World"; -if (str1 == str2) { - // Strings are equal -} else { - // Strings are not equal -} - -``` - -### How to Find the Length of a String in C++? - -```cpp - -std::string myString = "Hello"; -int length = myString.length(); - -``` - -### How to Access Characters in a String in C++? -```cpp - -std::string myString = "Hello"; -char firstChar = myString[0]; - -``` - -### How to Modify a String in C++? - -```cpp - -std::string myString = "Hello"; -myString[0] = 'J'; // Changes 'H' to 'J' - -``` - -### How to Convert a String to Uppercase and Lowercase in C++? - -```cpp - -std::string myString = "Hello"; -std::transform(myString.begin(), myString.end(), myString.begin(), ::toupper); -// To lowercase: std::transform(myString.begin(), myString.end(), myString.begin(), ::tolower); - -``` - -### How to Convert a String to Integer in C++? -```cpp - -std::string numString = "123"; -int num = std::stoi(numString); - -``` - -### How to Convert an Integer to String in C++? -```cpp - -int num = 123; -std::string numString = std::to_string(num); - -``` - -### How to Convert a String to Character Array in C++? - -```cpp - -std::string myString = "Hello"; -const char* charArray = myString.c_str(); - -``` - -### How to Convert a Character Array to String in C++? - -```cpp - -const char* charArray = "Hello"; -std::string myString(charArray); - -``` - -### How to Convert a String to C-Style String in C++? - -```cpp - -std::string myString = "Hello"; -const char* cStyleString = myString.c_str(); - -``` - -### How to Convert a C-Style String to String in C++? - -```cpp -const char* cStyleString = "Hello"; -std::string myString(cStyleString); - -``` - -### How to Split a String in C++? -To split a string using a delimiter, we can use std::getline combined with std::stringstream to extract all the tokens from the string separated by a specified delimiter, and keep storing the token in a vector of string. diff --git a/docs/day-11/_category_.json b/docs/day-11/_category_.json deleted file mode 100644 index e2d8f2577..000000000 --- a/docs/day-11/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 11", - "position": 12, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-11/pass-by-reference.md b/docs/day-11/pass-by-reference.md deleted file mode 100644 index d288d53f4..000000000 --- a/docs/day-11/pass-by-reference.md +++ /dev/null @@ -1,130 +0,0 @@ ---- - -sidebar_position: 5 -title: "Passing by Reference in C++" -description: "In this tutorial, we will learn about passing by reference in C++ with the help of examples. Passing by reference is a crucial concept for optimizing memory usage and improving performance in C++ programming." -sidebar_label: "Passing by Reference" -slug: passing-by-reference-in-cpp ---- - -## 1. What is Passing by Reference in C++? - -Passing by reference is a method of passing arguments to a function such that the function operates on the actual variables rather than a copy of them. This allows the function to modify the original variables and is more efficient for large data structures. - -![Passing by Reference in C++](../../static/img/day-11/passing-by-reference.png) - -## 2. Why Use Passing by Reference? - -- **Efficiency**: Avoids copying large data structures, saving time and memory. -- **Modify Original Data**: Allows functions to modify the original arguments. -- **Consistency**: Keeps data consistent across different scopes. - -## 3. Syntax for Passing by Reference - -Passing by reference is done using the reference operator (`&`) in the function parameter list. - -**Syntax:** - -```cpp -returnType functionName(dataType ¶meterName) { - // Function body -} -``` - -## 4. Examples - -### Example 1: Basic Passing by Reference - -In this example, we pass an integer by reference to a function that increments its value. - -```cpp -#include <iostream> -using namespace std; - -void increment(int &num) { - num++; // Modifies the original variable -} - -int main() { - int a = 10; - increment(a); - cout << "a: " << a << endl; // Output: 11 - return 0; -} -``` - -### Example 2: Passing Objects by Reference - -Passing objects by reference can significantly improve performance by avoiding the overhead of copying large objects. - -```cpp -#include <iostream> -using namespace std; - -class Example { -public: - int value; - Example(int v) : value(v) {} -}; - -void modify(Example &obj) { - obj.value += 10; -} - -int main() { - Example ex(20); - modify(ex); - cout << "ex.value: " << ex.value << endl; // Output: 30 - return 0; -} -``` - -## 5. Const References - -When you do not want the function to modify the passed argument, use `const` with the reference. This ensures the argument is not changed within the function. - -**Syntax:** - -```cpp -returnType functionName(const dataType ¶meterName) { - // Function body -} -``` - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -void display(const int &num) { - cout << "Number: " << num << endl; - // num++; // Error: Cannot modify a const reference -} - -int main() { - int a = 10; - display(a); - return 0; -} -``` - -## 6. When to Use Passing by Reference - -- When you need to modify the original variable. -- When passing large objects to avoid copying overhead. -- When consistency of data across function calls is required. - -## 7. Advantages and Disadvantages - -### Advantages -- **Performance**: More efficient for large data structures. -- **Modifiability**: Allows functions to modify the original arguments. - -### Disadvantages -- **Complexity**: Can make the function interface more complex. -- **Safety**: Requires careful handling to avoid unintended modifications. - -## 8. Conclusion - -Passing by reference is a powerful feature in C++ that enhances performance and allows functions to modify the original data. Understanding when and how to use it effectively is crucial for efficient C++ programming. \ No newline at end of file diff --git a/docs/day-11/pass-by-value.md b/docs/day-11/pass-by-value.md deleted file mode 100644 index caeb16ea3..000000000 --- a/docs/day-11/pass-by-value.md +++ /dev/null @@ -1,131 +0,0 @@ ---- - -sidebar_position: 3 -title: "Pass By Value in C++" -description: "In this tutorial, we will learn about Pass By Value in C++ programming with the help of examples. Pass By Value means passing a copy of the actual parameter to the function. Changes made to the parameter inside the function do not affect the original variable." -sidebar_label: "Pass By Value" -slug: pass-by-value-in-cpp ---- - -Before going to Pass By Reference, one should properly learn about Pass By Value. So here we go... - -## 1. What is Pass By Value in C++? - -Pass By Value in C++ means passing a copy of the actual parameter to a function. The function operates on the copy, and any modifications to the parameter inside the function do not affect the original variable. This method ensures that the original data remains unchanged. - -![Passing by Value in C++](../../static/img/day-11/reference-in-cpp.png) - -## 2. Explain the Syntax of Pass By Value in C++. - -The syntax for passing by value is straightforward. You simply pass the variable as an argument to the function. The function definition includes the parameter type and name without any special symbols. - -**Syntax:** - -```cpp -void functionName(dataType parameter); -``` - -## 3. How to Use Pass By Value in C++? - -**Using Pass By Value** -When you use pass by value, you call the function with the actual parameter, and a copy of it is passed to the function. - -```cpp -#include <iostream> - -void increment(int num) { - num++; - std::cout << "Inside function: " << num << std::endl; // Outputs: 6 -} - -int main() { - int value = 5; - increment(value); - std::cout << "Outside function: " << value << std::endl; // Outputs: 5 - return 0; -} -``` - -### 4. C++ Pass By Value Example -Here is a simple example demonstrating pass by value: - -**Example:** - -```cpp -#include <iostream> - -void multiplyByTwo(int num) { - num = num * 2; - std::cout << "Inside function: " << num << std::endl; // Outputs: 20 -} - -int main() { - int original = 10; - multiplyByTwo(original); - - std::cout << "Outside function: " << original << std::endl; // Outputs: 10 - return 0; -} -``` - -### 5. Advantages of Pass By Value - -- **Data Safety**: Since the function works on a copy, the original data remains unchanged. -- **Simplicity**: Easy to understand and implement, especially for small data types. - - -### 6. Disadvantages of Pass By Value - -- **Performance**: For large data types, copying can be inefficient and consume more memory. -- **Limited Modifiability**: The function cannot modify the original variable. - -### 7. When to Use Pass By Value? - -- **Small Data Types**: Use pass by value for small data types like integers, characters, and small structures. -- **Read-Only Operations**: When you do not need to modify the original variable and only need to read its value. - -**Example of Pass By Value with Small Data Types:** - -```cpp -#include <iostream> - -void display(char ch) { - std::cout << "Character: " << ch << std::endl; -} - -int main() { - char letter = 'A'; - display(letter); - - return 0; -} -``` - -**Example of Pass By Value with Structures:** - -```cpp -#include <iostream> - -struct Point { - int x, y; -}; - -void displayPoint(Point p) { - std::cout << "Point: (" << p.x << ", " << p.y << ")" << std::endl; -} - -int main() { - Point pt = {10, 20}; - displayPoint(pt); - - return 0; -} -``` - -By using pass by value, you ensure **data integrity** while performing read-only operations or working with small data types. However, be mindful of performance implications when dealing with larger objects. - -## 8. Conclusion - -Pass by value is a fundamental concept in C++ programming, providing a straightforward way to pass data to functions. While it has its advantages, such as **data safety** and **simplicity**, it also has performance drawbacks for large data types. Understanding when and how to use pass by value effectively is crucial for writing efficient and maintainable C++ code. - -By understanding the differences between pass by value and other parameter passing methods, such as pass by reference, you can make informed decisions about the best approach to use in your C++ programming. \ No newline at end of file diff --git a/docs/day-11/pointers-in-array.md b/docs/day-11/pointers-in-array.md deleted file mode 100644 index 66d35e0f4..000000000 --- a/docs/day-11/pointers-in-array.md +++ /dev/null @@ -1,92 +0,0 @@ ---- -sidebar_position: 2 -title: "Pointers in Array in C++" -description: "In this tutorial, we will learn about Pointers in Array in C++ programming with the help of examples. A pointer is a variable that stores the memory address of another variable. Pointers are used to store the address of variables, arrays, and functions in C++." -sidebar_label: "Pointers in Array" -slug: pointers-in-array-in-cpp ---- - -### 1. What are Pointers in Array? -- In C++, pointers can be used with arrays to access their elements and perform operations. So, when we define a pointer to an array, we are essentially creating a pointer that points to the same address as the array name. -- Here is a simple program that demonstrates the use of pointers in array. -```cpp -#include <iostream> -using namespace std; - -int main() -{ - int arr[5] = { 10, 20, 30, 40, 50 }; - int* ptr = arr; //Pointer to the first element of an array - - cout << "*arr = " << *arr << endl; //An array name is a pointer to its first element - cout << "arr = " << arr << endl; - cout << "*ptr = " << *ptr << endl; - cout << "ptr = " << ptr << endl; - - return 0; -} - -``` -Output -``` -*arr = 10 -arr = 0x7ffc096e3bc0 -*ptr = 10 -ptr = 0x7ffc096e3bc0 -``` - -### 2. Why do we need pointers in array? -- They provide a way to pass arrays to functions without passing the entire array (which can be inefficient if the array is large). -- They allow us to dynamically allocate memory for arrays at runtime. -- They can be used to implement data structures like linked lists, trees, etc. - -### 3. Example Program to Traverse an Array using Pointer -```cpp -#include<iostream> -using namespace std; - -int main() { - int arr[] = {18, 23, 36, 45, 57}; - int *ptr = arr; // Pointer to the first element of the array - - for(int i = 0; i < 5; i++) { - cout << "Element at index " << i << " is: " << *(ptr + i) << endl; - } - - return 0; -} -``` -Output -``` -Element at index 0 is: 18 -Element at index 1 is: 23 -Element at index 2 is: 36 -Element at index 3 is: 45 -Element at index 4 is: 57 -``` -Here, -- arr is an Array of Integers. -- *ptr is a Pointer that points to the first element of the Array arr. -- The for loop iterates over each element of the array. *(ptr + i) gives the value at the ith index of the array. This is because adding i to the pointer ptr moves it i places in memory. Since ptr is a pointer to an integer, each move is the size of an integer. - -### Practice Questions -1. What is a Pointer in C++? -2. Explain the Syntax of a Pointer in C++. -3. How to Declare and Define a Pointer in C++? -4. How to Access the Value of a Pointer in C++? -5. How to Access the Address of a Pointer in C++? -6. How to Declare and Define a Pointer to a Pointer in C++? -7. How do you initialize a pointer to point to the first element ofan array? -8. Explain how pointer arithmetic works in the context of arrays? -9. How can you pass an array to a function using pointers? -10. What is the significance of null pointer in C++? -11. How do you iterate over an array using pointers? -12. Explain how memory is managed when using pointers with array in C++? -13. What is a pointer decay and how does it related to array? -14. Write a program to swap two elements in array using pointers? -15. How do you dynamically allocate an array using pointers? - - - -IMAGE FILE: -![Function in CPP](../../static/img/day-11/array-with-pointers.png) diff --git a/docs/day-11/pointers-in-cpp.md b/docs/day-11/pointers-in-cpp.md deleted file mode 100644 index d0bbc62a8..000000000 --- a/docs/day-11/pointers-in-cpp.md +++ /dev/null @@ -1,257 +0,0 @@ ---- -sidebar_position: 1 -title: "Pointers in C++" -description: "In this tutorial, we will learn about Pointers in C++ programming with the help of examples. A pointer is a variable that stores the memory address of another variable. Pointers are used to store the address of variables, arrays, and functions in C++." -sidebar_label: "Pointers" -slug: pointers-in-cpp ---- - -## What is a Pointer in C++? - -A pointer is a variable that stores the memory address of an object. Pointers are used extensively in both C and C++ for three main purposes: - -- To allocate new objects on the heap, -- To pass functions to other functions -- To iterate over elements in arrays or other data structures. - -In C-style programming, raw pointers are used for all these scenarios. However, raw pointers are the source of many serious programming errors. Therefore, their use is strongly discouraged except where they provide a significant performance benefit and there is no ambiguity as to which pointer is the owning pointer that is responsible for deleting the object. Modern C++ provides smart pointers for allocating objects, iterators for traversing data structures, and lambda expressions for passing functions. By using these language and library facilities instead of raw pointers, you will make your program safer, easier to debug, and simpler to understand and maintain. - -## Explain the Syntax of a Pointer in C++. - -Here's how to declare a pointer in C++: - -```cpp -data_type* pointer_name; -``` -```cpp -int num = 10; -int* ptr = # -``` - -In this example, * is the dereference operator. It is used to access the value that the pointer is pointing to. For example, to print the value of num using the pointer ptr, you can use the following code: - -```cpp -cout << *ptr << endl; -``` - -This will print the value 10 to the console. -Pointers can be used to point to any type of data, including arrays, structures, and classes. They can also be used to point to functions. - - -![Multidimentional-array](../../static/img/day-11/pointers.png) - -## How to Declare and Define a Pointer in C++? - -Declare the pointer variable. - -To declare a pointer variable, you need to use the * operator. For example, to declare a pointer variable named ptr that points to an integer variable named num, you can use the following code: - -```cpp -int* ptr; -``` - -This code declares a pointer variable named ptr that points to an integer variable. - -Initialize the pointer variable. - -Once you have declared the pointer variable, you need to initialize it. To initialize a pointer variable, you need to assign it the address of a variable. For example, to initialize the pointer variable ptr to point to the integer variable num, you can use the following code: - -```cpp -ptr = # -``` - -## How to Access the Value of a Pointer in C++? - -To access the value of a pointer in C++, you need to use the dereferencing operator (*). The dereferencing operator returns the value of the variable that the pointer points to. - -For example, if you have a pointer to an integer variable, you can use the dereferencing operator to get the value of the integer variable. - -Here is an example: - -```cpp -int my_int = 10; -int* my_pointer = &my_int; - -// Get the value of the integer variable using the dereferencing operator -int value = *my_pointer; - -// Print the value of the integer variable -std::cout << value << std::endl; -``` - -This code will print the value 10 to the console. -You can also use the dereferencing operator to modify the value of the variable that the pointer points to. -For example, you can use the following code to increment the value of the integer variable: - -```cpp -*my_pointer++; -``` - -## How to Access the Address of a Pointer in C++? - -To access the address of a pointer in C++, you can use the address-of operator (&). This operator returns the memory address of the variable that it is applied to. For example, if you have the following code: - -```cpp -int x = 10; -int *ptr = &x; -``` - -The variable ptr will store the memory address of the variable x. You can then use the dereference operator (*) to access the value stored at the memory location pointed to by ptr. For example, the following code will print the value 10 to the console: - -```cpp -cout << *ptr << endl; -``` - -## How to Declare and Define a Pointer to a Pointer in C++? - -To declare a pointer to a pointer in C++, you need to use the asterisk (*) symbol twice. For example, the following code declares a pointer to a pointer to an integer: - -```cpp -int** pInt; -``` -This means that the variable pInt can store the address of a pointer to an integer. -To define a pointer to a pointer, you need to assign it the address of a pointer to an integer. For example, the following code defines pInt to point to the pointer pInt2: - -```cpp -int* pInt2 = new int; -pInt = &pInt2; -``` - -The new operator allocates a new integer on the heap and returns a pointer to it. The & operator gets the address of a variable. So, the above code assigns the address of pInt2 to pInt. -Once pInt is defined, you can use it to access the integer that pInt2 points to. For example, the following code prints the value of the integer to the console: - -```cpp -cout << *pInt << endl; -``` - -## How to Declare and Define a Pointer to an Array in C++? - -To declare a pointer to an array in C++, you can use the following syntax: - -```cpp -// Declare a pointer to an array of integers -int* arr_ptr; - -// Initialize the pointer to point to the first element of the array -arr_ptr = &arr[0]; -``` - -Here, arr_ptr is a pointer to an array of integers. The & operator is used to get the address of the first element of the array. -To access the elements of the array through the pointer, you can use the dereference operator (*). For example, the following code will print the first element of the array: - -```cpp -cout << *arr_ptr << endl; -``` - -You can also use the pointer to iterate over the elements of the array. For example, the following code will print all elements of the array: - -```cpp -for (int i = 0; i < 10; i++) { - cout << *(arr_ptr + i) << endl; -} -``` - -Here, the arr_ptr + i expression gives the address of the ith element of the array. - -Here is an example of how to use a pointer to an array in C++: - -```cpp -#include <iostream> - -using namespace std; - -int main() { - // Declare an array of integers - int arr[10] = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; - - // Declare a pointer to the array - int* arr_ptr = arr; - - // Print the elements of the array using the pointer - for (int i = 0; i < 10; i++) { - cout << *(arr_ptr + i) << endl; - } - - return 0; -} -``` - -Output: - -```cpp -1 -2 -3 -4 -5 -6 -7 -8 -9 -10 -``` - -## How to Declare and Define a Pointer to a Function in C++? - -To declare a pointer to a function in C++, you can use the following syntax: - -```cpp -// Declare a pointer to a function that takes two integers as arguments and returns an integer -int (*function_pointer)(int, int); - -// Define the function that the pointer will point to -int add(int a, int b) { - return a + b; -} - -// Assign the address of the function to the pointer -function_pointer = add; - -// Call the function through the pointer -int result = function_pointer(1, 2); - -// Print the result -std::cout << result << std::endl; -``` - -Output: - -```cpp -3 -``` - -In this example, we first declare a pointer to a function that takes two integers as arguments and returns an integer. We then define the function that the pointer will point to, which is a function called add() that takes two integers as arguments and returns their sum. We then assign the address of the add() function to the pointer. Finally, we call the add() function through the pointer and print the result. -Function pointers can be useful for a variety of purposes, such as passing functions as arguments to other functions or storing functions in an array. They can also be used to implement callback functions, which are functions that are called when a certain event occurs. - -## How to Pass a Pointer to a Function in C++? - -Here are the steps on how to pass a pointer to a function in C++: -- Declare a function that takes a pointer as a parameter. - -For example, the following function takes an integer pointer as a parameter and increments the value pointed to by the pointer: - -```cpp -void increment(int *p) { - *p += 1; -} -``` - -- Declare a pointer variable and point it to the variable or array you want to pass to the function. - -For example, the following code declares a pointer variable named p and points it to the integer variable x: - -```cpp -int x = 5; -int *p = &x; -``` - -- Call the function by passing the pointer as an argument. - -For example, the following code calls the increment() function and passes the pointer p as an argument: - -```cpp -increment(p); -``` - -After the increment() function is called, the value of the variable x will be incremented to 6. -Here is an example of a complete program that passes a pointer to a function: \ No newline at end of file diff --git a/docs/day-11/reference-in-cpp.md b/docs/day-11/reference-in-cpp.md deleted file mode 100644 index 3d0641d6d..000000000 --- a/docs/day-11/reference-in-cpp.md +++ /dev/null @@ -1,157 +0,0 @@ ---- -sidebar_position: 4 -title: "Reference in C++" -description: "In this tutorial, we will learn about Reference in C++ programming with the help of examples. A reference is an alias for a variable. It is a way to access the value of a variable using a different name. A reference is similar to a pointer, but it is simpler to use and safer than a pointer." -sidebar_label: "Reference" -slug: reference-in-cpp ---- - -## 1. What is a Reference in C++? - -When a variable is declared as a reference, it becomes an alternative name for an existing variable. A variable can be declared as a reference by putting ‘&’ in the declaration. - -Also, we can define a reference variable as a type of variable that can act as a reference to another variable. ‘&’ is used for signifying the address of a variable or any memory. Variables associated with reference variables can be accessed either by its name or by the reference variable associated with it. - -## 2. Explain the Syntax of a Reference in C++. - -The syntax for declaring a reference involves using the `&` symbol. You place the `&` symbol between the data type and the reference variable name. - -```cpp -dataType &referenceName = variableName; -``` - -## 3. How to Declare and Define a Reference in C++? - -### Declaring and Defining a Reference - -When you declare and define a reference, you must initialize it at the same time. References cannot be left uninitialized. - -```cpp -int original = 10; -int &ref = original; // 'ref' is a reference to 'original' -``` - -## 4. C++ Reference Example - -Here is a simple example demonstrating the use of a reference: - -```cpp -#include <iostream> - -int main() { - int original = 10; - int &ref = original; - - std::cout << "Original: " << original << std::endl; // Outputs: 10 - std::cout << "Reference: " << ref << std::endl; // Outputs: 10 - - ref = 20; - std::cout << "After modifying reference:" << std::endl; - std::cout << "Original: " << original << std::endl; // Outputs: 20 - std::cout << "Reference: " << ref << std::endl; // Outputs: 20 - - return 0; -} -``` - -![String in CPP](../../static/img/day-11/reference-in-cpp.png) - - -## 5. How to Pass a Reference to a Function in C++? - -To pass a reference to a function, you use the same `&` syntax in the function parameter list. This allows the function to modify the original variable. - -```cpp -#include <iostream> - -void increment(int &num) { - num++; -} - -int main() { - int value = 5; - increment(value); - std::cout << "Value after increment: " << value << std::endl; // Outputs: 6 - return 0; -} -``` - -## 6. How to Return a Reference from a Function in C++? - -- Declare a function with return type and parameter as reference variables. -- Perform the required actions with the reference variable inside the function. -- Return the reference variable. - -For example, the following function returns a reference to an integer: - -```cpp -int& returnValue(int& x) { - // Print the address. - std::cout << "x = " << x << " The address of x is " << &x << std::endl; - - // Return reference. - return x; -} -``` - -This function can be used as follows: - -```cpp -int main() { - int x = 10; - - // Get a reference to x. - int& ref = returnValue(x); - - // Modify the value of x through the reference. - ref = 20; - - // Print the value of x. - std::cout << "x = " << x << std::endl; - - return 0; -} -``` - -Output: - -```cpp -x = 10 The address of x is 0x7ffeed345678 -x = 20 -``` - -### Example of Returning a Reference from a Function - -```cpp -#include <iostream> - -int& getElement(int arr[], int index) { - return arr[index]; // Returning a reference to the array element -} - -int main() { - int myArray[5] = {1, 2, 3, 4, 5}; - int &element = getElement(myArray, 2); // Get reference to the third element - - std::cout << "Original element: " << element << std::endl; // Outputs: 3 - element = 10; // Modify the element through the reference - std::cout << "Modified element: " << myArray[2] << std::endl; // Outputs: 10 - - return 0; -} -``` - -### Important Considerations - -- **Lifetime of the referred object**: Ensure that the object whose reference is returned is still alive when the reference is used. Returning references to local variables within a function is dangerous because the local variables will be destroyed when the function scope ends. -- **Const references**: Use const references when you don't need to modify the object, which helps in avoiding accidental changes. - -```cpp -const int& getElement(const int arr[], int index) { - return arr[index]; -} -``` - -By using references, you can efficiently manage large data and enhance performance by avoiding unnecessary copying of objects. - - diff --git a/docs/day-11/reference-vs-pointers.md b/docs/day-11/reference-vs-pointers.md deleted file mode 100644 index db7e7c246..000000000 --- a/docs/day-11/reference-vs-pointers.md +++ /dev/null @@ -1,201 +0,0 @@ ---- - -sidebar_position: 6 -title: "References vs Pointers in C++" -description: "In this tutorial, we will learn about the differences between references and pointers in C++ with the help of examples. Understanding references and pointers is crucial for effective C++ programming." -sidebar_label: "References vs Pointers" -slug: references-vs-pointers-in-cpp ---- - -## 1. What are References and Pointers in C++? - -In C++, both references and pointers are used to refer to memory locations, but they have different properties and uses. - -- **References**: An alias for another variable. -- **Pointers**: A variable that holds the memory address of another variable. - -![References vs Pointers in C++](../../static/img/day-11/references-vs-pointers.png) - -## 2. Declaring References and Pointers - -### Declaring References - -A reference is declared using the `&` operator. - -**Syntax:** - -```cpp -datatype &referenceName = variableName; -``` - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10; - int &ref = a; // ref is a reference to a - cout << "a: " << a << endl; // Output: 10 - cout << "ref: " << ref << endl; // Output: 10 - return 0; -} -``` - -### Declaring Pointers - -A pointer is declared using the `*` operator. - -**Syntax:** - -```cpp -datatype *pointerName; -``` - -**Example:** - -```cpp -#include <iostream> -using namespace std; - -int main() { - int a = 10; - int *ptr = &a; // ptr holds the address of a - cout << "a: " << a << endl; // Output: 10 - cout << "ptr: " << ptr << endl; // Output: address of a - cout << "*ptr: " << *ptr << endl; // Output: 10 - return 0; -} -``` - -## 3. Differences Between References and Pointers - -### 1. Syntax and Usage - -- **References**: Use the `&` operator for declaration and do not require dereferencing. -- **Pointers**: Use the `*` operator for declaration and require dereferencing with `*`. - -**Example:** - -```cpp -int a = 5; -int &ref = a; // Reference -int *ptr = &a; // Pointer -``` - -### 2. Initialization - -- **References**: Must be initialized when declared. -- **Pointers**: Can be declared without initialization and assigned later. - -**Example:** - -```cpp -int a = 5; -int &ref = a; // Must be initialized -int *ptr; // Can be declared without initialization -ptr = &a; // Assigned later -``` - -### 3. Reassignment - -- **References**: Cannot be reassigned to refer to another variable. -- **Pointers**: Can be reassigned to point to different variables. - -**Example:** - -```cpp -int a = 5, b = 10; -int &ref = a; // Reference to a -// ref = b; // Error: Cannot reassign a reference - -int *ptr = &a; // Pointer to a -ptr = &b; // Pointer reassigned to b -``` - -### 4. Null Values - -- **References**: Cannot be null. -- **Pointers**: Can be null (useful to indicate that they are not pointing to any valid memory). - -**Example:** - -```cpp -int a = 5; -int &ref = a; // Reference cannot be null - -int *ptr = nullptr; // Pointer can be null -ptr = &a; // Pointer assigned to a valid address -``` - -### 5. Memory Address - -- **References**: Implicitly provide the memory address of the referenced variable. -- **Pointers**: Explicitly hold and can be used to manipulate memory addresses. - -**Example:** - -```cpp -int a = 5; -int &ref = a; // Reference to a -int *ptr = &a; // Pointer to a - -cout << "Address of a: " << &a << endl; -cout << "Address using ref: " << &ref << endl; -cout << "Address using ptr: " << ptr << endl; -``` - -## 4. When to Use References and Pointers - -### Use References: -- When you need an alias for another variable. -- When you want to avoid null checks and pointer arithmetic. -- For pass-by-reference in function arguments to avoid copying large objects. - -### Use Pointers: -- When you need to allocate memory dynamically. -- When you need to implement data structures like linked lists, trees, etc. -- When you need to use null values to indicate "no object". - -## 5. Examples - -### Example 1: Using References - -```cpp -#include <iostream> -using namespace std; - -void increment(int &ref) { - ref++; -} - -int main() { - int a = 10; - increment(a); - cout << "a: " << a << endl; // Output: 11 - return 0; -} -``` - -### Example 2: Using Pointers - -```cpp -#include <iostream> -using namespace std; - -void increment(int *ptr) { - (*ptr)++; -} - -int main() { - int a = 10; - increment(&a); - cout << "a: " << a << endl; // Output: 11 - return 0; -} -``` - -## 6. Conclusion - -Both references and pointers are powerful features in C++ that allow you to manipulate memory and create more efficient programs. Understanding the differences between them and knowing when to use each is crucial for effective C++ programming. \ No newline at end of file diff --git a/docs/day-11/returning-by-reference.md b/docs/day-11/returning-by-reference.md deleted file mode 100644 index 112a77135..000000000 --- a/docs/day-11/returning-by-reference.md +++ /dev/null @@ -1,125 +0,0 @@ ---- -sidebar_position: 7 -title: "Returning by Reference in C++" -description: "In this tutorial, we will learn about returning by reference in C++ with the help of examples. Returning by reference is a useful technique to optimize performance and handle large data efficiently." -sidebar_label: "Returning by Reference" -slug: returning-by-reference-in-cpp ---- - -## 1. What is Returning by Reference in C++? - -Returning by reference allows a function to return a reference to a variable rather than a copy of its value. This technique can be used to modify the original variable or to avoid copying large objects, thus improving performance. - -![Returning by Reference in C++](../../static/img/day-11/returning-by-reference.png) - -## 2. Why Use Returning by Reference? - -- **Efficiency**: Avoids copying large objects, saving time and memory. -- **Direct Access**: Provides direct access to the variable, allowing modifications. -- **Consistent Data**: Ensures that the changes made are reflected across different scopes. - -## 3. Syntax for Returning by Reference - -A function can be defined to return a reference by using the reference operator (`&`) in the return type. - -**Syntax:** - -```cpp -dataType& functionName(parameters) { - // Function body -} -``` - -## 4. Examples - -### Example 1: Returning a Reference to a Local Variable - -Returning a reference to a local variable is incorrect and leads to undefined behavior because the local variable's lifetime ends when the function exits. - -**Incorrect Example:** - -```cpp -#include <iostream> -using namespace std; - -int& getLocalReference() { - int localVar = 10; - return localVar; // Warning: returning reference to local variable -} - -int main() { - int &ref = getLocalReference(); - cout << ref << endl; // Undefined behavior - return 0; -} -``` - -### Example 2: Returning a Reference to a Static Variable - -Returning a reference to a static variable is safe because static variables have a lifetime that extends across the entire program. - -```cpp -#include <iostream> -using namespace std; - -int& getStaticReference() { - static int staticVar = 10; - return staticVar; -} - -int main() { - int &ref = getStaticReference(); - cout << ref << endl; // Output: 10 - ref = 20; - cout << getStaticReference() << endl; // Output: 20 - return 0; -} -``` - -### Example 3: Returning a Reference from a Class Member Function - -Returning a reference to a member variable is common in classes. - -```cpp -#include <iostream> -using namespace std; - -class Example { -private: - int value; -public: - Example(int v) : value(v) {} - int& getValue() { - return value; - } -}; - -int main() { - Example ex(30); - int &ref = ex.getValue(); - cout << ref << endl; // Output: 30 - ref = 50; - cout << ex.getValue() << endl; // Output: 50 - return 0; -} -``` - -## 5. When to Use Returning by Reference - -- When you want to allow the caller to modify the returned variable. -- When dealing with large objects to avoid copying overhead. -- When you need the function to provide direct access to its internal variables. - -## 6. Advantages and Disadvantages - -### Advantages -- **Performance**: More efficient for large data structures. -- **Modifiability**: Allows functions to return variables that can be modified by the caller. - -### Disadvantages -- **Lifetime Issues**: Must ensure the returned reference remains valid. -- **Complexity**: Can make the function interface more complex and error-prone. - -## 7. Conclusion - -Returning by reference is a powerful feature in C++ that enhances performance and allows functions to return modifiable variables. Understanding when and how to use it effectively is crucial for efficient C++ programming. \ No newline at end of file diff --git a/docs/day-12/Access Specifiers.md b/docs/day-12/Access Specifiers.md deleted file mode 100644 index fe15ad4c9..000000000 --- a/docs/day-12/Access Specifiers.md +++ /dev/null @@ -1,51 +0,0 @@ ---- -sidebar_position: 3 ---- -# Access Specifiers in C++ - -Access specifiers in C++ are keywords that control the visibility and accessibility of class members. - -## Types of Access Specifiers - -### 1. Public -- **Description**: Public members are accessible from outside the class. -- **Usage**: -```cpp -class MyClass { -public: - int myPublicMember; - void myPublicFunction() { - // Function body - } -}; -``` -### 2. Private -- **Description**: Private members are accessible only within the class. -- **Usage**: -```cpp -class MyClass { -private: - int myPrivateMember; - void myPrivateFunction() { - // Function body - } -}; - -``` -### 3. Protected -- **Description**: Protected members are accessible within the class and its subclasses (derived classes). -- **Usage**: -```cpp -class MyBaseClass { -protected: - int myProtectedMember; -}; -class MyDerivedClass : public MyBaseClass { -public: - void myFunction() { - myProtectedMember = 10; // Accessing protected member of the base class - } -}; -``` - -Access specifiers provide control over data hiding and encapsulation, enabling better design and implementation of classes in C++. \ No newline at end of file diff --git a/docs/day-12/Class and object.md b/docs/day-12/Class and object.md deleted file mode 100644 index c8cb90003..000000000 --- a/docs/day-12/Class and object.md +++ /dev/null @@ -1,70 +0,0 @@ ---- -sidebar_position: 2 -title: "Class and Object in C++" -description: "In this tutorial, we will learn what is class and what is object." -sidebar_label: "Class and Object" -slug: class-and-object-in-cpp ---- - -## What is Class in C++? -A class is a blueprint or template for creating objects. It defines a type by bundling data and methods that work on the data into a single unit.A class encapsulates data for the object and methods to manipulate that data. - -Components of a Class: -1) Data Members: Variables that hold the data for the class. -2) Member Functions: Functions that operate on the data members and define the behavior of the class. - -## Syntax - -```cpp -class ClassName { -public: - // Public data members and member functions - int data; - void function() { - // Implementation - } - -private: - // Private data members and member functions - int privateData; - void privateFunction() { - // Implementation - } -}; -``` -## Example -```cpp -class Car { -public: - string brand; - string model; - int year; - - void displayInfo() { - cout << "Brand: " << brand << ", Model: " << model << ", Year: " << year << endl; - } -}; -``` - -## What is Object in C++? -An object is an instance of a class. When a class is defined, no memory is allocated until an object of that class is created. An object is a concrete entity based on a class and is composed of data members and member functions as defined in the class. - - ## Creating an Object: -Objects are created by declaring a variable of the class type. - -## Syntax -``` -ClassName objectName; -``` -## Example -``` -Car myCar; // Create an object of type Car -myCar.brand = "Toyota"; -myCar.model = "Corolla"; -myCar.year = 2020; -myCar.displayInfo(); // Call the member function -``` - - -IMAGE FILE: -![Class and Object in CPP](../..\static\img\day-12\oop2.png) \ No newline at end of file diff --git a/docs/day-12/Classes and Objects.md b/docs/day-12/Classes and Objects.md deleted file mode 100644 index fcfd5c73b..000000000 --- a/docs/day-12/Classes and Objects.md +++ /dev/null @@ -1,52 +0,0 @@ ---- -sidebar_position: 2 ---- - -# Classes and Objects in C++ - -## Classes - -In C++, a class is a user-defined data type that represents a blueprint for creating objects. It encapsulates data for the object and functions that operate on that data. - -### Class Definition -```cpp -class MyClass { -private: - int myNumber; - string myString; -public: - void setValues(int num, string str) { - myNumber = num; - myString = str; - } - void display() { - cout << "Number: " << myNumber << endl; - cout << "String: " << myString << endl; - } -}; -``` -- **Access Specifiers**: `private`, `public`, and `protected` control the access level of class members. -- **Private members**: Can only be accessed within the class. -- **Public members**: Can be accessed from outside the class. - -## Objects - -An object is an instance of a class. It represents a real-world entity and can store data and perform actions using member functions. - -### Object Creation -```cpp -MyClass obj1; // Creating an object of MyClass -MyClass obj2; // Another object of MyClass -``` - -### Usage - -```cpp -obj1.setValues(10, "Hello"); -obj2.setValues(20, "World"); - -obj1.display(); // Output: Number: 10 String: Hello -obj2.display(); // Output: Number: 20 String: World -``` - -In this example, `obj1` and `obj2` are instances of the `MyClass` class. The `setValues` function sets the values of `myNumber` and `myString` for each object, and the `display` function prints these values. \ No newline at end of file diff --git a/docs/day-12/Examples.md b/docs/day-12/Examples.md deleted file mode 100644 index 389cd6400..000000000 --- a/docs/day-12/Examples.md +++ /dev/null @@ -1,80 +0,0 @@ ---- -sidebar_position: 3 -title: "Examples of Class and Object in C++" -description: "In this tutorial, we will learn to work with class and objects." -sidebar_label: "Examples" -slug: Examples-in-cpp ---- - -## Example 1 - -```cpp - -#include <iostream> -using namespace std; - -class Person { -public: - // Data members - string name; - int age; - - // Member function to display person's information - void displayInfo() { - cout << "Name: " << name << ", Age: " << age << endl; - } -}; -int main() { - // Create an object of class Person - Person person1; - person1.name = "Alice"; - person1.age = 30; - - // Call the member function to display person's information - person1.displayInfo(); - - return 0; -} -``` -In this example: - -Person is a class with two data members (name and age) and one member function (displayInfo). -person1 is an object of the Person class, and we assign values to its data members and call its member function. - -## Example 2 - -```cpp - -#include <iostream> -using namespace std; - -class Dog { -public: - // Data members - string breed; - int age; - - // Member function to display dog's information - void displayInfo() { - cout << "Breed: " << breed << ", Age: " << age << " years" << endl; - } -}; -int main() { - // Create an object of class Dog - Dog dog1; - dog1.breed = "Golden Retriever"; - dog1.age = 3; - - // Call the member function to display dog's information - dog1.displayInfo(); - - return 0; -} -``` -In this example: - -Dog is a class with two data members (breed and age) and one member function (displayInfo). -dog1 is an object of the Dog class, and we assign values to its data members and call its member function. - -IMAGE FILE: -![Class and Object in CPP](../..\static\img\day-12\oop3.png) \ No newline at end of file diff --git a/docs/day-12/_category_.json b/docs/day-12/_category_.json deleted file mode 100644 index e653f80a6..000000000 --- a/docs/day-12/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 12", - "position": 13, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-12/destructors.md b/docs/day-12/destructors.md deleted file mode 100644 index 345fc367f..000000000 --- a/docs/day-12/destructors.md +++ /dev/null @@ -1,27 +0,0 @@ ---- -sidebar_position: 4 -title: "Destructors" -description: "They're used to clean up when an object goes out of scope or is deleted. " -sidebar_label: "Destructors" -slug: destructors ---- - -### Definition - -Destructor is an instance member function that is invoked automatically whenever an object is going to be destroyed. Meaning, a destructor is the last function that is going to be called before an object is destroyed. - -![destructors](../../static/img/day-12/destructors.jpg) - -### Syntax -The destructor has the same name as the class preceded by a tilde (~) and does not take any arguments. - -```cpp -class Example { -public: - ~Example() { - std::cout << "Destructor Called" << std::endl; - } -}; - -``` -Destructors are essential for releasing resources, such as memory or file handles, that the object may have acquired during its lifetime. \ No newline at end of file diff --git a/docs/day-12/dma-in-cpp.md b/docs/day-12/dma-in-cpp.md deleted file mode 100644 index 8fd9e7189..000000000 --- a/docs/day-12/dma-in-cpp.md +++ /dev/null @@ -1,102 +0,0 @@ ---- -sidebar_position: 2 -title: "Dynamic Memory Allocation in C++" -description: "In this tutorial we will apply the concept of dynamic memory allocation in C++. The purpose of this tutorial is to explore how the new and delete works in C++." -sidebar_label: "Dynamic Memory Allocation in C++" -slug: dma-in-cpp ---- -C++ provides two primary operations for Dynamic memory allocation: -* Allocating the memory using the `new` keyword. -* De-allocating the previously allocated memory using the `delete` keyword. - -## 1. Allocating memory using the `new` keyword - -The new keyword in C++ is used for dynamic memory allocation. It allows you to allocate memory for variables or objects during runtime. -### Memory Allocation -When you use `new`, memory is allocated from the heap. The heap is a region of memory that is managed by the operating system, and it's separate from the stack memory where local variables are typically stored. -The new operator returns a pointer to the memory location where the new object or variable is stored. - -If the memory allocation fails (e.g., due to insufficient memory), new throws a `std::bad_alloc` exception. - -### Syntax for using the `new` keyword -The syntax for the `new` keyword is: -``` -data_type *ptr_name= new data_type; -``` -![dma-in-cpp](../../static/img/day-12/dmaInCpp.png) - -## 2. Deallocating the previously allocated memory using the `delete` keyword - -The `delete` keyword in C++ is used to deallocate memory that was allocated dynamically using the new keyword. - -### Matching Allocation and Deallocation -*When you dynamically allocate memory using `new`, you must deallocate it once it's no longer needed to prevent memory leaks. `delete` is used to perform this deallocation. - -Memory allocated with new persists until explicitly deallocated. Therefore it is necessary to match the `new` keyword with `delete`. - -### Syntax for using the `delete` keyword -To delete an allocated memory we can simply use the `delete` keyword with the pointer pointing to the allocated memory. - -* For deallocating memory for a single object: `delete pointer;` -* For deallocating memory for an array of objects: `delete[] pointer;` - -#### Example -``` -int *ptr = new int; // Allocate memory -delete ptr; // Deallocate memory -``` -Attempting to delete a null pointer (a pointer that doesn't point to any valid memory address) has no effect. It's safe to delete a null pointer. - -Deleting a pointer that was not allocated with `new` leads to undefined behavior. - -Accessing memory through a pointer after it has been deleted results in undefined behavior. It may lead to a crash, or the program may appear to work correctly despite accessing invalid memory. - -## 3. Examples -Example C++ program that takes the number of elements as input from the user and creates an array using Dynamic Memory Allocation (DMA). - -``` -#include <iostream> -using namespace std; -int main() { - int n; - // Ask the user to enter the number of elements - cout << "Enter the number of elements: "; - cin >> n; - - // Dynamically allocate memory for an array of integers - int *arr = new int[n]; - - // Input values into the array - cout << "Enter " << n << " integers:" << std::endl; - for (int i = 0; i < n; ++i) { - cin >> arr[i]; - } - - // Display the elements of the array - cout << "Elements of the array:" << endl; - for (int i = 0; i < n; i++) { - cout << arr[i] << " "; - } - - // Deallocate memory - delete[] arr; - return 0; -} -``` -### Output: -``` -Enter the number of elements: 5 -Enter 5 integers: -1 -2 -3 -4 -5 -Elements of the array: -1 2 3 4 5 - -=== Code Execution Successful === -``` - - - diff --git a/docs/day-12/dynamic-array_and_smart-pointer.md b/docs/day-12/dynamic-array_and_smart-pointer.md deleted file mode 100644 index 1a0e1ebeb..000000000 --- a/docs/day-12/dynamic-array_and_smart-pointer.md +++ /dev/null @@ -1,71 +0,0 @@ ---- -sidebar_position: 2 -title: "Memory Management - Dynamic Arrays and Smart Pointers" -description: "In this tutorial, we will learn about dynamic arrays and smart pointers in C++ programming with the help of examples. Dynamic arrays allow flexible array sizing, and smart pointers manage memory automatically." -sidebar_label: "Dynamic Arrays and Smart Pointers" -slug: memory-management-dynamic-arrays-smart-pointers ---- - -## Dynamic Arrays - -Dynamic arrays are arrays whose size can be determined at runtime. They are created using the `new` operator and must be deallocated using the `delete` operator to avoid memory leaks. - -- **Creating Dynamic Arrays:** - - Syntax: - ```cpp - type* array = new type[size]; - ``` - - Example: - ```cpp - int size = 5; - int* dynamicArray = new int[size]; - ``` - -- **Accessing and Modifying Elements:** - - Elements are accessed and modified using pointers. - - Example: - ```cpp - dynamicArray[0] = 1; // Assigns value to the first element - int value = dynamicArray[1]; // Retrieves value of the second element - ``` - -- **Deallocating Dynamic Arrays:** - - Syntax: - ```cpp - delete[] array; - ``` - - Example: - ```cpp - delete[] dynamicArray; - ``` - -## Smart Pointers - -Smart pointers are a feature of the C++ Standard Library that help manage dynamic memory by ensuring proper deallocation. They are part of the `<memory>` header. - -- **Types of Smart Pointers:** - - **`std::unique_ptr`:** - - Ensures that only one pointer can own a resource at a time. - - Automatically deletes the resource when the `unique_ptr` goes out of scope. - - Syntax: - ```cpp - std::unique_ptr<int> ptr(new int(10)); - ``` - - - **`std::shared_ptr`:** - - Allows multiple pointers to share ownership of a resource. - - The resource is deleted when the last `shared_ptr` pointing to it is destroyed. - - Syntax: - ```cpp - std::shared_ptr<int> ptr1 = std::make_shared<int>(10); - std::shared_ptr<int> ptr2 = ptr1; // Shared ownership - ``` - - - **`std::weak_ptr`:** - - Holds a non-owning reference to a resource managed by `std::shared_ptr`. - - Used to break cyclic dependencies between `shared_ptr`s. - - Syntax: - ```cpp - std::weak_ptr<int> weakPtr = sharedPtr; - ``` - diff --git a/docs/day-12/introduction-to-dma.md b/docs/day-12/introduction-to-dma.md deleted file mode 100644 index bdb3b6efb..000000000 --- a/docs/day-12/introduction-to-dma.md +++ /dev/null @@ -1,79 +0,0 @@ ---- -sidebar_position: 1 -title: "Introduction to Dynamic Memory Allocation" -description: "In this tutorial we will explore what dynamic memory allocation is and What is it used for. We will see how dynamic memory allocation is different from static memory allocation" -sidebar_label: "Introduction to Dynamic Memory Allocation" -slug: introduction-to-dma ---- -## 1. What is Dynamic Memory Allocation? -Dynamic memory allocation is a part of memory management techniques in C++. Dynamic memory allocation allows a user to allocated memory at runtime, during the execution. - -DMA empowers C++ programs to request memory from the operating system as needed during runtime. This is particularly useful when the size of data structures isn't known at compile time or needs to adjust dynamically throughout the program's execution. Unlike static memory allocation on the stack (fixed size), DMA leverages the heap, a more flexible memory region that expands and contracts as required. - -![Introduction-to-DMA](../../static/img/day-12/introduction.png) - -## 2. Need of Dynamic Memory Allocation -The question might arise that why do we need Dynamic Memory allocation and what are the benefits of doing so. - -#### The advantages of Dynamic Memory Allocation are: - -* **Flexibility**: It empowers you to allocate memory for data structures whose exact size is unknown until runtime. This is particularly useful for user input, reading data from files, or creating complex data structures like linked lists and trees that require dynamic memory allocation. - -* **Efficiency**: DMA promotes memory usage efficiency by allocating memory only when it's truly needed. This is beneficial for scenarios where data might not be used throughout the entire program, preventing memory waste. - -* **Scalability**: DMA excels at handling data structures that exhibit dynamic size changes during program execution. This makes it ideal for situations where you need to grow arrays, resize collections, or process data of varying sizes. - -## 3. Problem with Static Memory Allocation - -### **Fixed Sizes at Compile Time** -Once intialized, it is not possible to increase or decrease the size of the data structure we are using. - -**For Example** -``` -#include <iostream> -using namespace std; - -int main() { - int numbers[5]; - cout << "Enter 10 numbers: "; - for (int i = 0; i < 10; i++) { - cin >> numbers[i]; - } -} -``` -In the code above, we have initialized an integer array 'numbers' of size 5, however at during the runtime we are prompting user to enter 10 elements, this will result in a **buffer overflow error** because we are trying to access an index postion that does not exist in the array. - -### Memory Wastage -In case the programmer does not know about the required size of the structure in advance, static memory allocation often leads to wastage of memory. - -**For Example** -``` -#include<iostream> -using namespace std; - -int main(){ - int numbers[1000]; - int n; - //taking the number of elements as input from the user - cout << "Enter the number of Elements to be enters in the array" << endl; - cin >> n; - for(auto i=0; i < n; i++) - cin >> numbers[i]; - return 0; -} -``` -In the above example, as the programmer does not know how many elements the user is going to enter at runtime, to be on the safe side one often declares a structure of size much greater than required i.e 1000 in this example. - -Let's say the user enters only 5 elements at the runtime, the space of other 995 elements or memory location then gets wasted as those memory blocks are reserved for the array of size 1000 elements and thus cannot be reused by any other structure. - -This phenomenon is often called **Internal Fragmentation**. Internal fragmentation occurs when a statically allocated data structure (like an array or struct) wastes some space within its allocated block. This wasted space cannot be used by other variables because the entire block is reserved for that specific data structure. - - - - - - - - - - diff --git a/docs/day-12/introduction.md b/docs/day-12/introduction.md deleted file mode 100644 index c4a6d6d3d..000000000 --- a/docs/day-12/introduction.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -sidebar_position: 1 -title: "Introduction to Constructors" -description: "A constructor is a special member function that is executed whenever an object of the class is created. " -sidebar_label: "Introduction" -slug: introduction ---- - -### Definition - -A constructor is a special member function that is executed whenever an object of the class is created. Constructors are used to initialize objects. - -![introduction](../../static/img/day-12/introduction.png) - -### Syntax -The constructor has the same name as the class and does not have a return type. - -```cpp -class ClassName { -public: - ClassName() { - // Constructor body - } -}; -``` \ No newline at end of file diff --git a/docs/day-12/member-init-list.md b/docs/day-12/member-init-list.md deleted file mode 100644 index c9ba284b4..000000000 --- a/docs/day-12/member-init-list.md +++ /dev/null @@ -1,26 +0,0 @@ ---- -sidebar_position: 3 -title: "Member Initializer List" -description: "Constructors can also initialize class members using an initializer list, which can be more efficient." -sidebar_label: "Member Initializer List" -slug: member-init-list ---- - -### What does it mean? - -Constructors can also initialize class members using an initializer list, which can be more efficient. - -```cpp -class Example { -public: - int value; - - // Using Initializer List - Example(int v) : value(v) { - std::cout << "Constructor with Initializer List Called" << std::endl; - } -}; -``` -Using an initializer list is often more efficient than assigning values in the constructor body, especially for complex data members or base class initialization. - -![member-init-list](../../static/img/day-12/member-init-list.png) diff --git a/docs/day-12/memoryleak.md b/docs/day-12/memoryleak.md deleted file mode 100644 index 7e9a0027c..000000000 --- a/docs/day-12/memoryleak.md +++ /dev/null @@ -1,39 +0,0 @@ ---- -sidebar_position: 3 -title: "Memory Management - Memory Leaks and How to Avoid Them" -description: "In this tutorial, we will learn about memory leaks in C++ programming, how to identify them, and best practices to avoid them. Proper memory management is crucial for efficient and reliable software." -sidebar_label: "Memory Leaks and How to Avoid Them" -slug: memory-management-memory-leaks-avoidance ---- - -## Memory Leaks and How to Avoid Them - -Memory leaks occur when dynamically allocated memory is not deallocated, leading to wasted memory resources. They can cause programs to consume more memory over time, potentially leading to system crashes or slowdowns. - -- **Identifying Memory Leaks:** - - Use memory profiling tools like Valgrind, Dr. Memory, or built-in tools in IDEs to detect leaks. - - Regularly review code to ensure every `new` has a corresponding `delete`. - -- **Avoiding Memory Leaks:** - - **Always Pair `new` with `delete`:** - - Ensure that every allocation using `new` or `new[]` is paired with a corresponding `delete` or `delete[]`. - - **Use RAII (Resource Acquisition Is Initialization):** - - Tie resource management to object lifetimes. For example, use stack-allocated objects whose destructors handle resource cleanup. - - Example: - ```cpp - class Resource { - public: - Resource() { data = new int[100]; } - ~Resource() { delete[] data; } - private: - int* data; - }; - ``` - - **Utilize Smart Pointers:** - - Prefer using smart pointers (`std::unique_ptr`, `std::shared_ptr`) which automatically manage memory. - - Example: - ```cpp - std::unique_ptr<int> ptr(new int(10)); // Memory automatically managed - ``` - -By understanding and properly using these tools and techniques, you can effectively manage memory in your C++ programs, avoid common pitfalls, and ensure efficient use of resources. diff --git a/docs/day-12/new_and_delete.md b/docs/day-12/new_and_delete.md deleted file mode 100644 index 488d177ca..000000000 --- a/docs/day-12/new_and_delete.md +++ /dev/null @@ -1,43 +0,0 @@ ---- -sidebar_position: 1 -title: "Memory Management - new and delete Operators" -description: "In this tutorial, we will learn about `new` and `delete` operators in C++ programming with the help of examples. These operators are used for dynamic memory allocation and deallocation in C++." -sidebar_label: "New and Delete Operators" -slug: memory-management-new-delete-operators ---- - - -## Memory Management in C++ -Memory management is a critical aspect of programming in C++, as it involves allocating and deallocating memory dynamically at runtime. Proper memory management ensures that programs run efficiently and avoid issues such as memory leaks, fragmentation, and corruption. - -#### `new` and `delete` Operators - -The `new` and `delete` operators are fundamental for dynamic memory management in C++. They allow you to allocate and deallocate memory during runtime. - -- **`new` Operator:** - - Allocates memory from the heap. - - Returns a pointer to the allocated memory. - - Syntax: - ```cpp - type* pointer = new type; // For a single element - type* pointer = new type[size]; // For an array - ``` - - Example: - ```cpp - int* p = new int; // Allocates memory for a single integer - int* arr = new int[10]; // Allocates memory for an array of 10 integers - ``` - -- **`delete` Operator:** - - Deallocates memory that was previously allocated using `new`. - - Frees the memory, making it available for future allocations. - - Syntax: - ```cpp - delete pointer; // For a single element - delete[] pointer; // For an array - ``` - - Example: - ```cpp - delete p; // Deallocates memory for the single integer - delete[] arr; // Deallocates memory for the array of integers - ``` diff --git a/docs/day-12/object-oriented-programming.md b/docs/day-12/object-oriented-programming.md deleted file mode 100644 index bb5b2560c..000000000 --- a/docs/day-12/object-oriented-programming.md +++ /dev/null @@ -1,388 +0,0 @@ ---- -sidebar_position: 1 -title: "Pointers in Array in C++" -description: "In this tutorial, we will learn about Pointers in Array in C++ programming with the help of examples. A pointer is a variable that stores the memory address of another variable. Pointers are used to store the address of variables, arrays, and functions in C++." -sidebar_label: "Pointers in Array" -slug: oops-in-cpp ---- - - -## C++ OOPS Basics - -## What is OOP - -- OOP stands for Object-Oriented Programming. An object-oriented programming language uses objects in its programming. Programming with object-oriented concepts aims to emulate real-world concepts such as inheritance, polymorphism, abstraction, etc, in a program. -- C++ language was designed with the main intention of adding object-oriented programming to C language. As the size of the program increases, the readability, maintainability, and bug-free nature of the program decrease. The main aim of OOP is to bind together the data and the functions that operate on them so that no other part of the code can access this data except that function. -- This was the major problem with languages like C which relied upon functions or procedures (hence the name procedural programming language). As a result, the possibility of not addressing the problem adequately was high. Also, data was almost neglected, and data security was easily compromised. Using classes solves this problem by modeling the program as a real-world scenario. - -## Basic Elements of OOPS - -- **Classes** - Basic template for creating objects. This is the building block of object-oriented programming. -- **Objects** – Basic run-time entities and instances of a class. -- **Data Abstraction & Encapsulation** – Wrapping data and functions into a single unit. -- **Inheritance** – Properties of one class can be inherited into others. -- **Polymorphism** – Ability to take more than one form. -- **Dynamic Binding** – Code which will execute is not known until the program runs. -- **Message Passing** – message (Information) call format. - -## Benefits of OOPS - -- Programs involving OOP is faster and easier to execute. -- By using objects and inheritance, it provides a clear structure for programs and improves code reusability. -- It makes the code easier to maintain, modify and debug. -- Principle of data hiding helps build secure systems -- Multiple Objects can co-exist without any interference -- Software complexity can be easily managed so that even the creation of fully reusable software with less code and shorter development time is possible. - -## C++ Classes and Objects - -**Classes** - -Classes and structures are somewhat the same but still, they have some differences. For example, we cannot hide data in structures which means that everything is public and can be accessed easily which is a major drawback of the structure because structures cannot be used where data security is a major concern. Another drawback of structures is that we cannot add functions to them. - -Classes are user-defined data types and are a template or blueprint for creating objects. Classes consist of variables and functions which are also called class members. - -The syntax of a class in C++ is - -```cpp -class class_name -{ - //body of the class -}; -``` - -**Objects** - -Objects are instances of a class. To create an object, we just have to specify the class name and then the object’s name. Objects can access class attributes and methods which are bound to the class definition. It is recommended to put these attributes and methods in access modifiers so that their permissions can be better specified to allow them to be used by objects. - -The syntax for defining an object in C++ is - -```cpp -class class_name -{ - //body of the class -}; - -int main() -{ - class_name object_name; //object -} -``` - -## Class Attributes and Methods - -Class attributes and methods are variables and functions that are defined inside the class. They are also known as class members altogether. - -Consider an example below to understand what class attributes are - -```cpp -#include <iostream> -using namespace std; - -class Employee -{ - string eID; - string eName; - int ePhone; - public: -}; - - -int main() -{ - Employee E; -} -``` - -A class named Employee is built and three members, eId, eName and ePhone are defined inside the class. These three members are variables and are known as class attributes. Now, an object named E is defined in the main. E can access these attributes using the dot operator. But they are not accessible to E unless they are made public. - -```cpp -#include <iostream> -using namespace std; - -class Employee -{ -public: - string eID; - string eName; - long long int ePhone; -}; - -int main() -{ - Employee Aman; - E.eID = "123456"; - E.eName = "Aryavir Singh"; - E.ePhone = 24402298893; - cout << "Employee having ID " << E.eID << " is " << E.eName << endl; - cout << "Employee contact number : " << E.ePhone; -} -``` -Class methods are nothing but functions that are defined in a class or belong to a class. Methods belonging to a class are accessed by their objects in the same way that they access attributes. Functions can be defined in two ways so that they belong to a class. - -**Define inside the class** - -An example that demonstrates defining functions inside classes is - -```cpp -class Employee -{ -public: - int eID; - string eName; - - void printName() - { - cout << eName << endl; - } -}; -``` - -**Define outside the class** - -Although, a function can be defined outside the class, it needs to be declared inside. Later, we can use the scope resolution operator (::) to define the function outside. - -An example that demonstrates defining functions outside classes is - -```cpp -class Employee -{ -public: - int eID; - string eName; - - void printName(); -}; - -void Employee::printName() -{ - cout << eName << endl; -} -``` - -## Friend Function - -Friend functions are those functions that have the right to access the private data of members of the class even though they are not defined inside the class. It is necessary to write the prototype of the friend function. -Declaring a friend function inside a class does not make that function a member of the class. - -**Properties of a Friend Function** - -- Not in the scope of the class, means it is not a member of the class. -- Since it is not in the scope of the class, it cannot be called from the object of that class. -- Can be declared anywhere inside the class, be it under the public or private access modifier, it will not make any difference. -- It cannot access the members directly by their names, it needs (object_name.member_name) to access any member. - -The syntax for declaring a friend function inside a class is - -```cpp -class class_name -{ - friend return_type function_name(arguments); -}; - -return_type class_name::function_name(arguments) -{ - //body of the function -} -``` -## Encapsulation - -Encapsulation is the first pillar of Object Oriented Programming. It means wrapping up data attributes and methods together. The goal is to keep sensitive data hidden from users. -Encapsulation is considered a good practice where one should always make attributes private for them to become non-modifiable until needed. The data is ultimately more secure as a result of this. Once members are made private, methods to access them or change them should be declared. - -An example of how encapsulation is achieved is - -```cpp -#include <iostream> -using namespace std; - -class class_name -{ -private: - int a; - -public: - void setA(int num) - { - a = num; - } - - int getA() - { - return a; - } -}; - -int main() -{ - class_name obj; - obj.setA(5); - cout << obj.getA() << endl; -} -``` -## Inheritance - -**What is inheritance** - -The concept of reusability in C++ is supported using inheritance. We can reuse the properties of an existing class by inheriting it and deriving its properties. The existing class is called the base class and the new class which is inherited from the base class is called the derived class. - -The syntax for inheriting a class is - -```cpp -// Derived Class syntax -class derived_class_name : access_modifier base_class_name -{ - // body of the derived class -} -``` -**Types of Inheritance** - -- **Single Inheritance** - -Single inheritance is a type of inheritance in which a derived class is inherited with only one base class. - -For example, we have two classes ClassA and ClassB. If ClassB is inherited from ClassA, it means that ClassB can now implement the functionalities of ClassA. This is single inheritance - -```cpp -class ClassA -{ - //body of ClassA -}; - -//derived from ClassA -class ClassB : public ClassA -{ - //body of ClassB -}; -``` - -- **MUltiple Inheritance** - -Multiple inheritances is a type of inheritance in which one derived class is inherited from more than one base class. - -For example, we have three classes ClassA, ClassB, and ClassC. If ClassC is inherited from both ClassA & ClassB, it means that ClassC can now implement the functionalities of both ClassA & ClassB. This is multiple inheritances. - -```cpp -class ClassA -{ - //body of ClassA -}; - -class ClassB -{ - //body of ClassB -}; - -//derived from ClassB and Class C -class ClassC : public ClassA, public ClassB -{ - //body of ClassC -}; -``` - -- **Hierarchial Inheritance** - -A hierarchical inheritance is a type of inheritance in which several derived classes are inherited from a single base class. - -For example, we have three classes ClassA, ClassB, and ClassC. If ClassB and Class C are inherited from ClassA, it means that ClassB and ClassC can now implement the functionalities of ClassA. This is hierarchical inheritance. - -```cpp -class ClassA -{ - //body of ClassA -}; - -//derived from ClassA -class ClassB : public ClassA -{ - //body of ClassB -}; - -//derived from ClassA -class ClassC : public ClassA -{ - //body of ClassC -}; -``` - -- **Multilevel Inheritance** - -Multilevel inheritance is a type of inheritance in which one derived class is inherited from another derived class. - -For example, we have three classes ClassA, ClassB, and ClassC. If ClassB is inherited from ClassA and ClassC is inherited from ClassB, it means that ClassB can now implement the functionalities of ClassA and ClassC can now implement the functionalities of ClassB. This is multilevel inheritance. - -```cpp -class ClassA -{ - //body of ClassA -}; - -//derived from ClassA -class ClassB : public ClassA -{ - //body of ClassB -}; - -//derived from ClassB -class ClassC : public ClassB -{ - //body of ClassC -}; -``` - -- **Hybrid Inheritance** - -Hybrid inheritance is a combination of different types of inheritances. - -For example, we have four classes ClassA, ClassB, ClassC, and ClassD. If ClassC is inherited from both ClassA and ClassB and ClassD is inherited from ClassC, it means that ClassC can now implement the functionalities of both ClassA and ClassB and ClassD can now implement the functionalities of ClassC. This is multilevel inheritance where both multilevel and multiple inheritances are present. - -```cpp -class ClassA -{ - //body of ClassA -}; - -class ClassB -{ - //body of ClassB -}; - -//derived from ClassA and ClassA -class ClassC : public ClassA, public ClassB -{ - //body of ClassC -}; - -//derived from ClassC -class ClassD : public ClassC -{ - //body of ClassD -}; -``` -## Polymorphism - -Poly means several and morphism means form. Polymorphism is something that has several forms or we can say it as one name and multiple forms. -There are two types of polymorphism: - -- Compile-time polymorphism -- Run time polymorphism - -**Compile Time Polymorphism** - -In compile-time polymorphism, it is already known which function will run. Compile-time polymorphism is also called early binding, which means that you are already bound to the function call and you know that this function is going to run. - -There are two types of compile-time polymorphism: - -- **Function Overloading** -This is a feature that lets us create more than one function and the functions have the same names but their parameters need to be different. When function overloading is implemented in a program and function calls are made, the compiler knows which functions to execute. - -- **Operator Overloading** -This is a feature that lets us define operators working for some specific tasks. Using the operator +, we can add two strings by concatenating and add two numerical values arithmetically at the same time. This is operator overloading. - -**Run Time Polymorphism** - -With run-time polymorphism, the compiler has no idea what will happen when the code is executed. Run time polymorphism is also called late binding. The run-time polymorphism is considered slow because function calls are decided at run time. Run time polymorphism can be achieved from virtual functions. - -**Virtual Functions in C++** - -A member function in the base class that is declared using a virtual keyword is called a virtual function. They can be redefined in the derived class. A function that is in the parent class but redefined in the child class is called a virtual function. diff --git a/docs/day-12/oops-in-cpp.md b/docs/day-12/oops-in-cpp.md deleted file mode 100644 index b581bc7fb..000000000 --- a/docs/day-12/oops-in-cpp.md +++ /dev/null @@ -1,143 +0,0 @@ ---- -sidebar_position: 1 ---- - -# Object-Oriented Programming (OOP) in C++ - -## Introduction -Object-Oriented Programming (OOP) is a programming paradigm that revolves around the concept of "objects," which can contain data and code to manipulate that data. C++ is a powerful language that supports OOP principles. This document provides an overview of key OOP concepts in C++ along with examples. - -## Key Concepts - -### 1. Classes and Objects -- **Definition**: A class is a blueprint for creating objects. It defines attributes (data members) and methods (functions) that operate on those attributes. -- **Example**: -```cpp -class Rectangle { -private: - int length; - int width; -public: - void setDimensions(int len, int wid) { - length = len; - width = wid; - } - int area() { - return length * width; - } -}; -``` -- **Usage**: -```cpp -Rectangle rect1, rect2; -rect1.setDimensions(5, 3); -cout << "Area of rect1: " << rect1.area() << endl; - -``` - -### 2. Encapsulation -- **Definition**: Encapsulation is the bundling of data and methods within a single unit (class). Access specifiers control the access to class members. -- **Example**: -```cpp -class Circle { -private: - double radius; -public: - void setRadius(double r) { - if (r > 0) - radius = r; - } - double getArea() { - return 3.14 * radius * radius; - } -}; - -``` -- **Usage**: -```cpp -Circle circle; -circle.setRadius(5.0); -cout << "Area of circle: " << circle.getArea() << endl; -``` - -### 3. Inheritance -- **Definition**: Inheritance allows a class (subclass/derived class) to inherit properties and behavior from another class (superclass/base class). -- **Example**: -```cpp -class Animal { -public: - void eat() { - cout << "Animal is eating" << endl; - } -}; -class Dog : public Animal { -public: - void bark() { - cout << "Dog is barking" << endl; - } -}; - -``` -- **Usage**: -```cpp -Dog dog; -dog.eat(); // inherited from Animal -dog.bark(); -``` - -### 4. Polymorphism -- **Definition**: Polymorphism allows objects of different classes to be treated as objects of a common superclass. It can be achieved through function overloading and function overriding. -- **Example**: -```cpp -// Function overloading -int add(int a, int b) { - return a + b; -} -double add(double a, double b) { - return a + b; -} - -// Function overriding -class Shape { -public: - virtual double area() { - return 0; - } -}; -class Circle : public Shape { -public: - double area() override { - return 3.14 * radius * radius; - } -}; - -``` -- **Usage**: -```cpp -cout << "Sum of 2 and 3: " << add(2, 3) << endl; -Circle circle; -cout << "Area of circle: " << circle.area() << endl; -``` - -### 5. Abstraction -- **Definition**: Abstraction involves hiding the complex implementation details and showing only the essential features of the object. -- **Example**: -```cpp -class Car { -private: - Engine engine; - // Other private members... -public: - void start() { - engine.start(); - } - // Other public methods... -}; - - -``` -- **Usage**: -```cpp -Car car; -car.start(); -``` \ No newline at end of file diff --git a/docs/day-12/oops.md b/docs/day-12/oops.md deleted file mode 100644 index 0aecd6af8..000000000 --- a/docs/day-12/oops.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -sidebar_position: 1 -title: "Object Oriented Programming in C++" -description: "Object-oriented programming – As the name suggests uses objects in programming. Object-oriented programming aims to implement real-world entities like inheritance, hiding, polymorphism, etc. in programming. " -sidebar_label: "Object Oriented Programming" -slug: oops ---- - -## What is Object Oriented Programming in C++? -Object means a real word entity such as pen, chair, table etc. Object-Oriented Programming is a methodology or paradigm to design a program using classes and objects. It simplifies the software development and maintenance by providing some concepts: -1) Object -2) Class -3) Inheritance -4) Polymorphism -5) Abstraction -6) Encapsulation -7) Dynamic Binding -8) Message Passing - -IMAGE FILE: -![OOP in CPP](C:\Users\Shruti\OneDrive\Desktop\30-Days-Of-CPP\static\img\day-12\oop1.png) - -## Basic characteristics of Object Oriented Programming -1) Object- An Object is an identifiable entity with some characteristics and behavior. An Object is an instance of a Class. When a class is defined, no memory is allocated but when it is instantiated (i.e. an object is created) memory is allocated. For example: chair, pen, table, keyboard, bike etc. It can be physical and logical. - -2)Class- Collection of objects is called class. It is a logical entity. A Class in C++ is the foundational element that leads to Object-Oriented programming. A class instance must be created in order to access and use the user-defined data type's data members and member functions. An object's class acts as its blueprint. - -3)Inheritance- When one object acquires all the properties and behaviours of parent object i.e. known as inheritance. It provides code reusability. It is used to achieve runtime polymorphism. - -4)Polymorphism- The word polymorphism means having many forms. In simple words, we can define polymorphism as the ability of a message to be displayed in more than one form. A person at the same time can have different characteristics. A man at the same time is a father, a husband, and an employee. So the same person possesses different behavior in different situations. This is called polymorphism.C++ supports operator overloading and function overloading- - -I)Operator Overloading: The process of making an operator exhibit different behaviors in different instances is known as operator overloading. -II)Function Overloading: Function overloading is using a single function name to perform different types of tasks. Polymorphism is extensively used in implementing inheritance. - -5)Abstraction-Data abstraction is one of the most essential and important features of object-oriented programming in C++. Abstraction means displaying only essential information and hiding the details. Data abstraction refers to providing only essential information about the data to the outside world, hiding the background details or implementation. - -6)Encapsulation-In normal terms, Encapsulation is defined as wrapping up data and information under a single unit. In Object-Oriented Programming, Encapsulation is defined as binding together the data and the functions that manipulate them. - -7)Dynamic Binding- In dynamic binding, the code to be executed in response to the function call is decided at runtime. C++ has virtual functions to support this. Because dynamic binding is flexible, it avoids the drawbacks of static binding, which connected the function call and definition at build time. - -8)Message Passing- Objects communicate with one another by sending and receiving information. A message for an object is a request for the execution of a procedure and therefore will invoke a function in the receiving object that generates the desired results. Message passing involves specifying the name of the object, the name of the function, and the information to be sent. \ No newline at end of file diff --git a/docs/day-12/pointers_to_structures.md b/docs/day-12/pointers_to_structures.md deleted file mode 100644 index 655ddf74d..000000000 --- a/docs/day-12/pointers_to_structures.md +++ /dev/null @@ -1,19 +0,0 @@ ---- -sidebar_position: 3 -title: "Pointers to structures in C++" -description: "In this tutorial, we will learn about pointers in structures in C++ programming with the help of examples. A pointer variable stores the address of the sturcture. " -sidebar_label: "Pointers to Structures" -slug: pointers-to-structures-in-cpp ---- - -TASK: - -1. For what type of data types can pointer variable be created? -2. Give an example of structure stored in a pointer variable? -3. For what is the arrow ( -> ) operator used for? -4. Write a C++ program to access members of a structure . - -Add more... - -IMAGE FILE: -![String in CPP](../../static/img/day-11/reference-in-cpp.png) \ No newline at end of file diff --git a/docs/day-12/problems-in-dma.md b/docs/day-12/problems-in-dma.md deleted file mode 100644 index 5a409bcc6..000000000 --- a/docs/day-12/problems-in-dma.md +++ /dev/null @@ -1,59 +0,0 @@ ---- -sidebar_position: 3 -title: "Problems due to dynamic memory allocation" -description: "In this tutorial we will apply the concept of dynamic memory allocation in C++. The purpose of this tutorial is to explore how the new and delete works in C++." -sidebar_label: "Problems due to dynamic memory allocation in C++" -slug: problems-in-dma ---- - -## 1. Memory Leakage -Memory leakage in C++ occurs when memory that is allocated dynamically is not deallocated properly, leading to a loss of memory that cannot be reused by the program. This can result in inefficient memory usage and can eventually cause the program to run out of memory. Memory leaks can be a significant issue, especially in long-running programs or systems where memory resources are limited. - -### Failure to Deallocate Dynamically Allocated Memory: -When memory is allocated using the keywords like `new` it is the responsibility of the programmer to deallocate the assigned memory after it is no longer needed, failure in doing so might lead to the memory leakage problem. - -``` -int main() { - int *ptr = new int; // Allocate memory - // No deallocation of memory - return 0; -} -``` -### Losing the pointer to Dynamically allocated memory -If the memory is allocated dynamically and pointer which is storing the address of the assigned memory gets overwritten without proper deallocation of the allocated memory it leads to memory leakage. - -``` -int main() { - int *ptr = new int; // Allocate memory - ptr = nullptr; // overwriting and losing the reference of allocated memory - return 0; -} - -``` -![Introduction-to-DMA](../../static/img/day-12/problems.png) - -## 2. Dangling pointers -Dangling pointers are pointers that point to memory that has been deallocated, freed, or otherwise invalidated. Accessing or dereferencing a dangling pointer can lead to undefined behavior, crashes, or unexpected results. - -When memory allocated using new is deallocated using delete, any pointers pointing to that memory become dangling pointers. If these pointers are accessed or dereferenced after deallocation, it leads to undefined behavior. - -``` -int* ptr = new int; // Allocate memory -delete ptr; // Deallocate memory -// ptr becomes a dangling pointer - -``` -After memory is deallocated, it can be reused for other purposes. If a dangling pointer is dereferenced after deallocation, it might accidentally access unrelated data stored in the same memory location, leading to unexpected behavior or program crashes. - -## 3. External Fragmentation -External fragmentation is a memory management issue that occurs when using dynamic memory allocation (DMA) in C++. It arises when there's sufficient free memory available in total to satisfy a memory allocation request, but the free memory is scattered across multiple non-contiguous blocks. These fragmented blocks are unusable because programs typically require contiguous memory to store data structures. - -Even though there's enough total free space to fit a new box (memory allocation request), it might not fit in any of the existing free spaces because they're not contiguous. -This can lead to situations where your program has to request more memory from the operating system even though there's technically "free" memory available. - -### Problems due to external fragmentation -* **Reduced Memory Efficiency**: The program might request more memory from the operating system even though there's technically free memory available. -* **Performance Degradation**: Frequent memory allocation requests can lead to performance overhead. -* **Program Crashes**: In severe cases, external fragmentation can make it impossible to allocate memory even when there's seemingly enough free memory, causing program crashes. - - diff --git a/docs/day-12/structures.md b/docs/day-12/structures.md deleted file mode 100644 index d4a251e43..000000000 --- a/docs/day-12/structures.md +++ /dev/null @@ -1,21 +0,0 @@ ---- -sidebar_position: 1 -title: "Structures in C++" -description: "In this tutorial, we will learn about Structures in C++ programming with the help of examples. A structure is a collection of variables of different data types and member functions under a single name. It is similar to a class as both hold a collection of data of different data types." -sidebar_label: "Structures" -slug: structures-in-cpp ---- - -TASK: - -1. Define a structure in C++? -2. State the syntax of a structure in C++. -3. How is a Structure similar to class in C++? -4. How much memory is allocated to a Structure in C++ when it is declared? -5. Write a C++ program defining a structure of an employee with members: ID, Name, Position, Designation? -6. How to access the members of a structure in C++? - -Add More... - -IMAGE FILE: -![Multidimentional-array](../../static/img/day-11/pointers.png) \ No newline at end of file diff --git a/docs/day-12/structures_and_functions.md b/docs/day-12/structures_and_functions.md deleted file mode 100644 index 944221275..000000000 --- a/docs/day-12/structures_and_functions.md +++ /dev/null @@ -1,21 +0,0 @@ ---- -sidebar_position: 2 -title: "Structures and Functions in C++" -description: "In this tutorial, we will learn ablout method and different ways to pass a structure in a function" -sidebar_label: "Structures and Functions in C++" -slug: functtions-of-structures-in-cpp ---- - -TASK: - -1. What is a Pointer in C++? -2. Explain the Syntax of a Pointer in C++. -3. How to Declare and Define a Pointer in C++? -4. How to Access the Value of a Pointer in C++? -5. How to Access the Address of a Pointer in C++? -6. How to Declare and Define a Pointer to a Pointer in C++? - -Add more... - -IMAGE FILE: -![Function in CPP](../../static/img/day-11/array-with-pointers.png) diff --git a/docs/day-12/types-of-constructors.md b/docs/day-12/types-of-constructors.md deleted file mode 100644 index 45f70ee48..000000000 --- a/docs/day-12/types-of-constructors.md +++ /dev/null @@ -1,73 +0,0 @@ ---- -sidebar_position: 2 -title: "Types of Constructors" -description: "Constructors can be classified based on in which situations they are being used." -sidebar_label: "Types of Constructors" -slug: types-of-constructors ---- - -Constructors can be classified based on in which situations they are being used. Each type of constructor serves a different purpose, from providing default values to copying the state from another object. - -![types-of-constructors](../../static/img/day-12/types-of-constructors.png) - -## 1. Default Constructor -A constructor that takes no arguments. - -```cpp -class Example { -public: - Example() { - std::cout << "Default Constructor Called" << std::endl; - } -}; -``` - -## 2. Parameterized Constructor -A constructor that takes arguments to initialize an object with specific values. - -```cpp -class Example { -public: - int value; - - Example(int v) { - value = v; - std::cout << "Parameterized Constructor Called with value: " << value << std::endl; - } -}; -``` - -## 3. Copy Constructor -A constructor that initializes an object using another object of the same class. - -```cpp -class Example { -public: - int value; - - Example(int v) { - value = v; - } - - Example(const Example &obj) { - value = obj.value; - std::cout << "Copy Constructor Called" << std::endl; - } -}; -``` - -## 4. Move Constructor - Move constructors are special member functions used to transfer resources from one object to another. Unlike copy constructors, which create a new copy of an object, move constructors "move" the resources, leaving the original object in a valid but unspecified state. - -Move constructors are particularly useful when dealing with resource-intensive objects like those managing dynamic memory, file handles, or network connections. - -```cpp -class ClassName { -public: - ClassName(ClassName&& other) { - // Move constructor body - } -}; -``` - - diff --git a/docs/day-13/Function-overloading.md b/docs/day-13/Function-overloading.md deleted file mode 100644 index c1962f873..000000000 --- a/docs/day-13/Function-overloading.md +++ /dev/null @@ -1,123 +0,0 @@ ---- -sidebar_position: 4 -title: "Function Overloading in C++" -description: "In this tutorial, we will learn about function overloading in C++ with the help of examples. Function overloading allows us to create multiple functions with the same name, each performing different tasks based on their parameters." -sidebar_label: "Function Overloading" -slug: function-overloading ---- - -## 1. What is Function Overloading in C++? - -Function overloading in C++ allows us to create multiple functions with the same name but different parameters. This enables us to perform different tasks using the same function name, enhancing code readability and reusability. - -![Function overloading in CPP](../../static/img/day-13/function-overloading.png) - -## 2. Why Use Function Overloading? - -Function overloading is useful when: -- We need to perform similar operations on different data types. -- We want to avoid using different function names for similar tasks, thus making the code more intuitive and easier to maintain. - -## 3. Syntax of Function Overloading - -To overload a function, define multiple functions with the same name but different parameters (different number, type, or order of parameters). - -```cpp -void functionName(int a); -void functionName(double a); -void functionName(int a, double b); -``` - -## 4. Examples of Function Overloading - -### 1. Overloading Functions Based on Parameter Type - -```cpp -#include <iostream> -using namespace std; - -void print(int i) { - cout << "Printing int: " << i << endl; -} - -void print(double f) { - cout << "Printing float: " << f << endl; -} - -int main() { - print(5); // Calls the first print function - print(3.14); // Calls the second print function - return 0; -} -``` - -### 2. Overloading Functions Based on Number of Parameters - -```cpp -#include <iostream> -using namespace std; - -void display(int a) { - cout << "Displaying integer: " << a << endl; -} - -void display(int a, double b) { - cout << "Displaying integer and double: " << a << " and " << b << endl; -} - -int main() { - display(5); // Calls the first display function - display(5, 3.14); // Calls the second display function - return 0; -} -``` - -### 3. Overloading Functions Based on Parameter Order - -```cpp -#include <iostream> -using namespace std; - -void show(int a, char b) { - cout << "Integer: " << a << " and character: " << b << endl; -} - -void show(char b, int a) { - cout << "Character: " << b << " and integer: " << a << endl; -} - -int main() { - show(100, 'A'); // Calls the first show function - show('B', 200); // Calls the second show function - return 0; -} -``` - -## 5. Rules for Function Overloading - -When overloading functions, the compiler must differentiate between the functions based on: -- The number of parameters -- The types of parameters -- The order of parameters - -However, you cannot overload functions by only changing the return type. - -**Example of Incorrect Overloading:** - -```cpp -// This will cause a compile-time error -int multiply(int a, int b); -double multiply(int a, int b); -``` - -## 6. Benefits of Function Overloading - -- **Improves code readability**: Function names are intuitive and consistent. -- **Reduces code complexity**: Similar operations grouped under the same function name. -- **Enhances maintainability**: Easier to manage and understand the code. - -## 7. Conclusion - -Function overloading is a powerful feature in C++ that enhances the flexibility and readability of the code. By allowing multiple functions with the same name but different parameters, it enables us to write cleaner, more maintainable programs. Understanding and utilizing function overloading effectively can significantly improve your programming skills and efficiency. - ---- \ No newline at end of file diff --git a/docs/day-13/_category_.json b/docs/day-13/_category_.json deleted file mode 100644 index 7ce246702..000000000 --- a/docs/day-13/_category_.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "label": "Day 13", - "position": 14, - "link": { - "type": "generated-index" - } - } - diff --git a/docs/day-13/about_oops.md b/docs/day-13/about_oops.md deleted file mode 100644 index 69fb452e9..000000000 --- a/docs/day-13/about_oops.md +++ /dev/null @@ -1,82 +0,0 @@ ---- -sidebar_position: 1 -title: "Concepts of OOP - Introduction to Object-Oriented Programming" -description: "In this tutorial, we will learn about the fundamentals of Object-Oriented Programming (OOP), including its core principles and benefits." -sidebar_label: "Introduction to OOP" -slug: concepts-of-oop-introduction ---- - -## Introduction to Object-Oriented Programming - -Object-Oriented Programming (OOP) is a programming paradigm based on the concept of "objects", which can contain data and code to manipulate that data. OOP is designed to increase the flexibility and maintainability of programs. - -- ### **Core Principles of OOP:** - 1. **Encapsulation:** - - Encapsulation is the mechanism of hiding the internal details of an object and only exposing a controlled interface. - - Example: - ```cpp - class Person { - private: - string name; - int age; - public: - void setName(string n) { name = n; } - string getName() { return name; } - }; - ``` - - 2. **Abstraction:** - - Abstraction means representing essential features without including background details. - - It allows focusing on what an object does instead of how it does it. - - Example: - ```cpp - class Animal { - public: - virtual void makeSound() = 0; // Pure virtual function - }; - class Dog : public Animal { - public: - void makeSound() override { - cout << "Bark" << endl; - } - }; - ``` - - 3. **Inheritance:** - - Inheritance allows a class to inherit properties and behavior from another class. - - It promotes code reusability. - - Example: - ```cpp - class Vehicle { - public: - string brand = "Ford"; - }; - class Car : public Vehicle { - public: - string model = "Mustang"; - }; - ``` - - 4. **Polymorphism:** - - Polymorphism means "many forms" and allows methods to do different things based on the object it is acting upon. - - Example: - ```cpp - class Shape { - public: - virtual void draw() { - cout << "Drawing Shape" << endl; - } - }; - class Circle : public Shape { - public: - void draw() override { - cout << "Drawing Circle" << endl; - } - }; - ``` - -- **Benefits of OOP:** - - **Modularity:** Code is divided into classes and objects, making it easier to manage and understand. - - **Reusability:** Classes can be reused in other programs. - - **Scalability:** Easy to add new features or objects. - - **Maintainability:** Easier to update and maintain code. \ No newline at end of file diff --git a/docs/day-13/oops_classes.md b/docs/day-13/oops_classes.md deleted file mode 100644 index 27866facb..000000000 --- a/docs/day-13/oops_classes.md +++ /dev/null @@ -1,42 +0,0 @@ ---- -sidebar_position: 2 -title: "Concepts of OOP - Classes" -description: "In this tutorial, we will learn about the concept of classes in Object-Oriented Programming (OOP) with the help of examples. Classes are the blueprint for creating objects." -sidebar_label: "Classes" -slug: concepts-of-oop-classes ---- - -## Classes - -Classes are the fundamental building blocks of Object-Oriented Programming (OOP). A class is a blueprint for creating objects, providing initial values for state (member variables or attributes), and implementations of behavior (member functions or methods). - -- ### **Defining a Class:** - - A class definition starts with the keyword `class` followed by the class name and a pair of curly braces `{}`. - - Member variables and member functions are declared within the class body. - - Syntax: - ```cpp - class ClassName { - public: - // Member variables - // Member functions - }; - ``` - -- **Example:** - - Defining a simple class `Car`: - ```cpp - class Car { - public: - string brand; - string model; - int year; - - void displayInfo() { - cout << "Brand: " << brand << endl; - cout << "Model: " << model << endl; - cout << "Year: " << year << endl; - } - }; - ``` - -In this example, `Car` is a class with three member variables (`brand`, `model`, `year`) and one member function (`displayInfo`). diff --git a/docs/day-13/oops_objects.md b/docs/day-13/oops_objects.md deleted file mode 100644 index 80035ba5c..000000000 --- a/docs/day-13/oops_objects.md +++ /dev/null @@ -1,63 +0,0 @@ ---- -sidebar_position: 3 -title: "Concepts of OOP - Objects" -description: "In this tutorial, we will learn how to create and use objects in Object-Oriented Programming (OOP) with the help of examples. Objects are instances of classes." -sidebar_label: "Objects" -slug: concepts-of-oop-objects ---- - -## Objects - -Objects are instances of classes. They are created using the class definition and can be used to access member variables and functions. - -- **Creating an Object:** - - Syntax: - ```cpp - ClassName objectName; - ``` - - Example: - ```cpp - Car myCar; - ``` - -- **Accessing Members:** - - Member variables and functions are accessed using the dot operator (`.`). - - Example: - ```cpp - myCar.brand = "Toyota"; - myCar.model = "Corolla"; - myCar.year = 2020; - myCar.displayInfo(); - ``` - -- **Example Program:** - - Creating and using an object of the `Car` class: - ```cpp - #include <iostream> - using namespace std; - - class Car { - public: - string brand; - string model; - int year; - - void displayInfo() { - cout << "Brand: " << brand << endl; - cout << "Model: " << model << endl; - cout << "Year: " << year << endl; - } - }; - - int main() { - Car myCar; - myCar.brand = "Toyota"; - myCar.model = "Corolla"; - myCar.year = 2020; - myCar.displayInfo(); - - return 0; - } - ``` - -In this example, an object `myCar` of the class `Car` is created, and its member variables are accessed and modified. diff --git a/docs/day-14/Create-References.md b/docs/day-14/Create-References.md deleted file mode 100644 index 7c2f3591f..000000000 --- a/docs/day-14/Create-References.md +++ /dev/null @@ -1,32 +0,0 @@ ---- -sidebar_position: 1 -title: "C++ References" -description: "In this tutorial, we will learn about the hoe to create References in C++." -sidebar_label: "Create References" -slug: C++ References ---- - -## Creating References - -A reference variable is a "reference" to an existing variable, and it is created with the & operator: - - - ```cpp - string food = "Pizza"; // food variable -string &meal = food; // reference to food - - ``` - - Now, we can use either the variable name food or the reference name meal to refer to the food variable: - ## Example - - ```cpp - string food = "Pizza"; -string &meal = food; - -cout << food << "\n"; // Outputs Pizza -cout << meal << "\n"; // Outputs Pizza - - ``` - - \ No newline at end of file diff --git a/docs/day-14/Memory-Address.md b/docs/day-14/Memory-Address.md deleted file mode 100644 index f4863e996..000000000 --- a/docs/day-14/Memory-Address.md +++ /dev/null @@ -1,25 +0,0 @@ ---- -sidebar_position: 2 -title: "C++ Memory Address" -description: "In this tutorial, we will learn about the concept of C++ memory Address ." -sidebar_label: "C++ Memory Address" -slug: memory address in c++ ---- - -## Memory Address - -In the example from the previous page, the & operator was used to create a reference variable. But it can also be used to get the memory address of a variable; which is the location of where the variable is stored on the computer. - -When a variable is created in C++, a memory address is assigned to the variable. And when we assign a value to the variable, it is stored in this memory address. - -To access it, use the & operator, and the result will represent where the variable is stored: - -- ### **Example** - - ```cpp - string food = "Pizza"; - - cout << &food; // Outputs 0x6dfed4 - ``` - -Note: The memory address is in hexadecimal form (0x..). Note that you may not get the same result in your program. diff --git a/docs/day-14/_category_.json b/docs/day-14/_category_.json deleted file mode 100644 index c522106bb..000000000 --- a/docs/day-14/_category_.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "label": "Day 14", - "position": 15, - "link": { - "type": "generated-index" - } - } - \ No newline at end of file diff --git a/docs/day-14/category_.json b/docs/day-14/category_.json deleted file mode 100644 index 17177565c..000000000 --- a/docs/day-14/category_.json +++ /dev/null @@ -1,8 +0,0 @@ -{ - "label": "Day 14", - "position": 15, - "link": { - "type": "generated-index" - } - } - \ No newline at end of file diff --git a/docs/day-14/constructor.md b/docs/day-14/constructor.md deleted file mode 100644 index c22691f4c..000000000 --- a/docs/day-14/constructor.md +++ /dev/null @@ -1,95 +0,0 @@ ---- -sidebar_position: 1 -title: "Constructors in C++ - Introduction and Purpose" -description: "In this tutorial, we will learn about constructors in C++ programming, their purpose, and how they are used to initialize objects." -sidebar_label: "Constructors- Introduction and Purpose" -slug: constructors-in-cpp-introduction ---- - -## Constructors in C++ - Introduction and Purpose - -A constructor is a special member function of a class that is automatically called when an object of that class is created. It is used to initialize the object's state. - -- ### **Purpose of Constructors:** - - **Initialization:** Constructors are primarily used to initialize the object's member variables to their initial values. When an object of a class is created, its member variables might need to be set to specific values to ensure the object's integrity and consistency. Constructors provide a means to achieve this initialization seamlessly. - - **Example:** - ```cpp - class Car { - public: - string brand; - string model; - int year; - - // Constructor for initialization - Car() { - brand = "Unknown"; - model = "Unknown"; - year = 0; - } - }; - ``` - - **Memory Allocation:** Constructors allocate memory for the object if necessary. In some cases, constructors are involved in memory allocation for the object. For instance, if the object requires dynamic memory allocation, such as when creating arrays or allocating memory for internal data structures, constructors can handle this allocation process, ensuring that the object has the necessary memory resources. - - **Example:** - ```cpp - class DynamicArray { - private: - int *arr; - int size; - - public: - // Constructor for memory allocation - DynamicArray(int s) { - size = s; - arr = new int[size]; - } - // Destructor for deallocating memory - ~DynamicArray() { - delete[] arr; - } - }; - ``` - - **Resource Acquisition:** Constructors can also be responsible for acquiring external resources required by the object, such as file handles, network connections, or database connections. By acquiring these resources during object initialization, constructors ensure that the object is fully operational and ready to perform its intended tasks without external dependencies. - - **Example:** - ```cpp - class FileHandler { - private: - FILE *file; - - public: - // Constructor for acquiring file resource - FileHandler(const char *filename) { - file = fopen(filename, "w"); - if (!file) { - cerr << "Error opening file" << endl; - } - } - // Destructor for releasing file resource - ~FileHandler() { - if (file) { - fclose(file); - } - } - }; - ``` - - - **Object Initialization:** Perhaps most importantly, constructors guarantee that the object is in a valid and consistent state when it is created. This aspect is crucial for maintaining the integrity of the object and preventing potential errors or unexpected behavior during its usage. Constructors enforce any necessary constraints or conditions to ensure that the object is properly initialized and ready for use. - - **Example:** - ```cpp - class Person { - private: - string name; - int age; - - public: - // Constructor for object initialization - Person(string n, int a) { - if (a < 0) { - cerr << "Invalid age" << endl; - age = 0; // Set default age - } else { - name = n; - age = a; - } - } - }; - ``` diff --git a/docs/day-14/destructor.md b/docs/day-14/destructor.md deleted file mode 100644 index 68a2bc9fb..000000000 --- a/docs/day-14/destructor.md +++ /dev/null @@ -1,41 +0,0 @@ ---- -sidebar_position: 3 -title: "Destructors in C++ - Introduction and Usage" -description: "In this tutorial, we will learn about destructors in C++ programming, their purpose, and how they are used to clean up resources and release memory when objects are destroyed." -sidebar_label: "Destructors" -slug: destructors-in-cpp-introduction ---- - -## Destructors in C++ - Introduction and Usage - -A destructor is a special member function of a class that is automatically called when an object is destroyed. It is used to release resources and clean up memory allocated by the object. - -- ### **Purpose of Destructors:** - - **Resource Deallocation:** Destructors release resources acquired by the object during its lifetime, such as memory, file handles, database connections, etc. This helps prevent resource leaks and ensures efficient resource management. - - - **Cleanup Operations:** Destructors perform cleanup operations to ensure that the object is properly disposed of before its memory is reclaimed. This may include releasing dynamically allocated memory, closing open files, releasing locks, or any other necessary cleanup tasks. - -- **Example:** - ```cpp - class Car { - public: - string brand; - string model; - int year; - - // Destructor - ~Car() { - // Cleanup code - } - }; - - -### Advanced Usage: - - - **Custom Resource Management:** Destructors enable custom resource management techniques such as RAII (Resource Acquisition Is Initialization), where resource acquisition is tied to object lifetime. This pattern ensures that resources are automatically released when objects go out of scope, leading to more robust and exception-safe code. - - - **Handling Exceptions:** Destructors play a crucial role in exception handling. If an exception occurs during object construction, the destructor is automatically invoked to clean up any resources allocated before the exception was thrown. This helps maintain program integrity by ensuring that resources are properly released, even in the presence of exceptions. - - - **Finalization and Cleanup:** Destructors are used for finalization and cleanup tasks beyond simple resource deallocation. This includes tasks like logging finalization messages, updating persistent storage, or performing additional cleanup operations specific to the object's role within the application. - - - **Scoped Resource Management:** Destructors enable scoped resource management, where resources are acquired and released within a well-defined scope. This ensures that resources are released as soon as they are no longer needed, minimizing resource contention and improving overall system efficiency. \ No newline at end of file diff --git a/docs/day-14/stl-algorithms.md b/docs/day-14/stl-algorithms.md deleted file mode 100644 index e69de29bb..000000000 diff --git a/docs/day-14/stl-containers.md b/docs/day-14/stl-containers.md deleted file mode 100644 index 3f74069ed..000000000 --- a/docs/day-14/stl-containers.md +++ /dev/null @@ -1,122 +0,0 @@ -### 2. stl-containers.md -```markdown ---- -sidebar_position: 2 -title: "STL Containers" -description: "In this tutorial, we will learn about various containers provided by the Standard Template Library (STL) in C++ with the help of examples. Containers are data structures that store objects and data." -sidebar_label: "STL Containers" -slug: stl-containers-in-cpp ---- - -## STL Containers - -### What are Containers in STL? -Containers are objects that store collections of other objects. The STL provides several different types of containers, each optimized for specific kinds of data manipulation. - -### Sequence Containers -1. **Vector**: A dynamic array that can grow in size. - ```cpp - #include <vector> - #include <iostream> - - int main() { - std::vector<int> vec = {1, 2, 3, 4, 5}; - vec.push_back(6); // Add element at the end - - for (int i : vec) { - std::cout << i << " "; - } - return 0; - } -2. **List**: A doubly-linked list. - ```cpp - #include <list> - #include <iostream> - - int main() { - std::list<int> lst = {1, 2, 3, 4, 5}; - lst.push_back(6); // Add element at the end - - for (int i : lst) { - std::cout << i << " "; - } - return 0; - } -3. **Deque**: A double-ended queue that allows fast insertion and deletion at both ends. - ```cpp - #include <deque> - #include <iostream> - - int main() { - std::deque<int> deq = {1, 2, 3, 4, 5}; - deq.push_front(0); // Add element at the front - - for (int i : deq) { - std::cout << i << " "; - } - return 0; - } -### Associative Containers - -1. **Set**: A collection of unique elements. - ```cpp - #include <set> - #include <iostream> - - int main() { - std::set<int> mySet = {1, 2, 3, 4, 5}; - mySet.insert(6); // Insert element - - for (int i : mySet) { - std::cout << i << " "; - } - return 0; -} -2. **Map**: A collection of key-value pairs. - ```cpp - #include <map> - #include <iostream> - - int main() { - std::map<int, std::string> myMap = {{1, "one"}, {2, "two"}, {3, "three"}}; - myMap[4] = "four"; // Insert element - - for (const auto& pair : myMap) { - std::cout << pair.first << ": " << pair.second << "\n"; - } - return 0; - } -### Container Containers - -1. **Stack**: A container adaptor that gives the functionality of a stack (LIFO). - ```cpp - #include <stack> - #include <iostream> - - int main() { - std::stack<int> myStack; - myStack.push(1); - myStack.push(2); - - while (!myStack.empty()) { - std::cout << myStack.top() << " "; - myStack.pop(); - } - return 0; - } -2. **Queue**: A container adaptor that gives the functionality of a queue (FIFO). - ```cpp - #include <queue> - #include <iostream> - - int main() { - std::queue<int> myQueue; - myQueue.push(1); - myQueue.push(2); - - while (!myQueue.empty()) { - std::cout << myQueue.front() << " "; - myQueue.pop(); - } - return 0; - } diff --git a/docs/day-14/stl-introduction.md b/docs/day-14/stl-introduction.md deleted file mode 100644 index e69de29bb..000000000 diff --git a/docs/day-14/stl-iterators.md b/docs/day-14/stl-iterators.md deleted file mode 100644 index 06f8ea9f2..000000000 --- a/docs/day-14/stl-iterators.md +++ /dev/null @@ -1,42 +0,0 @@ ---- -sidebar_position: 4 -title: "STL Iterators" -description: "In this tutorial, we will learn about Iterators in the Standard Template Library (STL) in C++ with the help of examples. Iterators are used to point to the elements of containers." -sidebar_label: "STL Iterators" -slug: stl-iterators-in-cpp ---- - -## STL Iterators - -### What are Iterators in STL? -Iterators are objects used to iterate through the elements of a container. They act as pointers and provide a way to access elements in a container sequentially. - -### Types of Iterators -1. **Input Iterator**: Reads elements from a sequence. -2. **Output Iterator**: Writes elements to a sequence. -3. **Forward Iterator**: Reads and writes elements sequentially. -4. **Bidirectional Iterator**: Supports moving forward and backward through a sequence. -5. **Random Access Iterator**: Provides random access to elements, supporting arithmetic operations like addition and subtraction. - -### Example: -```cpp -#include <iostream> -#include <vector> - -int main() { - std::vector<int> vec = {1, 2, 3, 4, 5}; - - // Forward iterator example - std::cout << "Forward traversal using iterators: "; - for (auto it = vec.begin(); it != vec.end(); ++it) { - std::cout << *it << " "; - } - - // Reverse iterator example - std::cout << "\nReverse traversal using reverse iterators: "; - for (auto rit = vec.rbegin(); rit != vec.rend(); ++rit) { - std::cout << *rit << " "; - } - - return 0; -} diff --git a/docs/day-14/typesofconstructor.md b/docs/day-14/typesofconstructor.md deleted file mode 100644 index 8dcf86069..000000000 --- a/docs/day-14/typesofconstructor.md +++ /dev/null @@ -1,72 +0,0 @@ ---- -sidebar_position: 2 -title: "Types of Constructors in C++" -description: "In this tutorial, we will learn about different types of constructors in C++ programming, including default, parameterized, copy, and delegating constructors." -sidebar_label: "Types of Constructors" -slug: types-of-constructors-in-cpp ---- - -## Types of Constructors in C++ - -There are several types of constructors in C++ that serve different purposes and have different ways of initializing objects. - -- ### **Default Constructor:** - - A constructor with no parameters. - - Automatically called when an object is created with no arguments. - - Example: - ```cpp - class Car { - public: - // Default Constructor - Car() { - // Initialization code - } - }; - ``` - -- ### **Parameterized Constructor:** - - A constructor with parameters. - - Used to initialize member variables with values provided during object creation. - - Example: - ```cpp - class Car { - public: - // Parameterized Constructor - Car(string b, string m, int y) { - brand = b; - model = m; - year = y; - } - }; - ``` - -- ### **Copy Constructor:** - - A constructor that creates a new object as a copy of an existing object. - - Automatically called when a new object is initialized with an existing object. - - Example: - ```cpp - class Car { - public: - // Copy Constructor - Car(const Car &other) { - brand = other.brand; - model = other.model; - year = other.year; - } - }; - ``` - -- ### **Delegating Constructor:** - - A constructor that calls another constructor of the same class. - - Used to avoid code duplication by reusing initialization logic. - - Example: - ```cpp - class Car { - public: - // Delegating Constructor - Car() : Car("Unknown", "Unknown", 0) {} - }; - ``` - -Each type of constructor serves a specific purpose and allows for flexible object initialization in C++. - diff --git a/docs/day-15/Abstraction.md b/docs/day-15/Abstraction.md deleted file mode 100644 index c32968a43..000000000 --- a/docs/day-15/Abstraction.md +++ /dev/null @@ -1,138 +0,0 @@ -# Abstraction in C++ - -Data abstraction is one of the most essential and important features of object-oriented programming in C++. Abstraction means displaying only essential information and hiding the details. Data abstraction refers to providing only essential information about the data to the outside world, hiding the background details or implementation. - -Consider a real-life example of a man driving a car. The man only knows that pressing the accelerator will increase the speed of the car or applying brakes will stop the car but he does not know how on pressing the accelerator the speed is actually increasing, he does not know about the inner mechanism of the car or the implementation of the accelerator, brakes, etc in the car. This is what abstraction is. - -## Advantages of Data Abstraction - -- Helps the user to avoid writing the low-level code. -- Avoids code duplication and increases reusability. -- Can change the internal implementation of the class independently without affecting the user. -- Helps to increase the security of an application or program as only important details are provided to the user. -- It reduces the complexity as well as the redundancy of the code, therefore increasing the readability. - -## Types of Abstraction: - -- **Data abstraction** - This type only shows the required information about the data and hides the unnecessary data. -- **Control Abstraction** - This type only shows the required information about the implementation and hides unnecessary information. - -## Abstraction using Classes - -We can implement Abstraction in C++ using classes. The class helps us to group data members and member functions using available access specifiers. A Class can decide which data member will be visible to the outside world and which is not. - -## Abstraction in Header files - -One more type of abstraction in C++ can be header files. For example, consider the pow() method present in math.h header file. Whenever we need to calculate the power of a number, we simply call the function pow() present in the math.h header file and pass the numbers as arguments without knowing the underlying algorithm according to which the function is actually calculating the power of numbers. - -## Abstraction using Access Specifiers - -Access specifiers are the main pillar of implementing abstraction in C++. We can use access specifiers to enforce restrictions on class members. For example: - -- Members declared as **public** in a class can be accessed from anywhere in the program. -- Members declared as **private** in a class, can be accessed only from within the class. They are not allowed to be accessed from any part of the code outside the class. - -We can easily implement abstraction using the above two features provided by access specifiers. Say, the members that define the internal implementation can be marked as private in a class. And the important information needed to be given to the outside world can be marked as public. And these public members can access the private members as they are inside the class. - -## Examples - -```cpp -// C++ Program to Demonstrate the -// working of Abstraction -#include <iostream> -using namespace std; - -class implementAbstraction { -private: - int a, b; - -public: - // method to set values of - // private members - void set(int x, int y) - { - a = x; - b = y; - } - - void display() - { - cout << "a = " << a << endl; - cout << "b = " << b << endl; - } -}; - -int main() -{ - implementAbstraction obj; - obj.set(10, 20); - obj.display(); - return 0; -} -``` -**Output** -``` -a = 10 -b = 20 -``` - -You can see in the above program we are not allowed to access the variables a and b directly, however, one can call the function set() to set the values in a and b and the function display() to display the values of a and b. - -```cpp -#include<iostream> -using namespace std; - -class Vehicle -{ - private: - void piston() - { - cout<<"4 piston\n"; - } - - void manWhoMade() - { - cout<<"Markus Librette\n"; - } - public: - void company() - { - cout<<"GFG\n"; - } - void model() - { - cout<<"SIMPLE\n"; - } - void color() - { - cout<<"Red/GREEN/Silver\n"; - } - void cost() - { - cout<<"Rs. 60000 to 900000\n"; - } - void oil() - { - cout<<"PETRO\n"; - } -}; -int main() -{ - - Vehicle obj; - obj.company(); - obj.model(); - obj.color(); - obj.cost(); - obj.oil(); -} -``` - -**Output** -``` -GFG -SIMPLE -Red/GREEN/Silver -Rs. 60000 to 900000 -PETRO -``` \ No newline at end of file diff --git a/docs/day-15/Encapsulation.md b/docs/day-15/Encapsulation.md deleted file mode 100644 index 75affec66..000000000 --- a/docs/day-15/Encapsulation.md +++ /dev/null @@ -1,104 +0,0 @@ -# Encapsulation in C++ - -Encapsulation in C++ is defined as the wrapping up of data and information in a single unit. In Object Oriented Programming, Encapsulation is defined as binding together the data and the functions that manipulate them. - -Consider a real-life example of encapsulation, in a company, there are different sections like the accounts section, finance section, sales section, etc. Now, -- The finance section handles all the financial transactions and keeps records of all the data related to finance. -- Similarly, the sales section handles all the sales-related activities and keeps records of all the sales. - -Now there may arise a situation when for some reason an official from the finance section needs all the data about sales in a particular month. - -In this case, he is not allowed to directly access the data of the sales section. He will first have to contact some other officer in the sales section and then request him to give the particular data. - -This is what **Encapsulation** is. Here the data of the sales section and the employees that can manipulate them are wrapped under a single name “sales section”. - -### Two Important property of Encapsulation - -- **Data Protection:** Encapsulation protects the internal state of an object by keeping its data members private. Access to and modification of these data members is restricted to the class’s public methods, ensuring controlled and secure data manipulation. - -- **Information Hiding:** Encapsulation hides the internal implementation details of a class from external code. Only the public interface of the class is accessible, providing abstraction and simplifying the usage of the class while allowing the internal implementation to be modified without impacting external code. - -## Features of Encapsulation - -Below are the features of encapsulation: -- We can not access any function from the class directly. We need an object to access that function that is using the member variables of that class. -- The function which we are making inside the class must use only member variables, only then it is called encapsulation. -- If we don’t make a function inside the class which is using the member variable of the class then we don’t call it encapsulation. -- Encapsulation improves readability, maintainability, and security by grouping data and methods together. -- It helps to control the modification of our data members. - -## Examples - -For example if we give input , and output should be half of input - -```cpp -#include <iostream> -using namespace std; -class temp{ - int a; - int b; - public: - int solve(int input){ - a=input; - b=a/2; - return b; - } -}; - -int main() { - int n; - cin>>n; - temp half; - int ans=half.solve(n); - cout<<ans<<endl; - -} -``` - -Let's take one more example. - -```cpp -// C++ program to demonstrate -// Encapsulation -#include <iostream> -using namespace std; - -class Encapsulation { -private: - // Data hidden from outside world - int x; - -public: - // Function to set value of - // variable x - void set(int a) { x = a; } - - // Function to return value of - // variable x - int get() { return x; } -}; - -// Driver code -int main() -{ - Encapsulation obj; - obj.set(5); - cout << obj.get(); - return 0; -} -``` -**Output** -``` -5 -``` - -## Role of Access Specifiers in Encapsulation - -Access specifiers facilitate Data Hiding in C++ programs by restricting access to the class member functions and data members. There are three types of access specifiers in C++: - -- **Private:** Private access specifier means that the member function or data member can only be accessed by other member functions of the same class. - -- **Public:** Public access specifier means that the member function or data member can be accessed by any code. -- **Protected:** A protected access specifier means that the member function or data member can be accessed by other member functions of the same class or by derived classes. - -By default, all data members and member functions of a class are made **private** by the compiler. \ No newline at end of file diff --git a/docs/day-15/_category_.json b/docs/day-15/_category_.json deleted file mode 100644 index 6379cb12c..000000000 --- a/docs/day-15/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 15", - "position": 16, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-16/_category_.json b/docs/day-16/_category_.json deleted file mode 100644 index 322780d96..000000000 --- a/docs/day-16/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 16", - "position": 16, - "link": { - "type": "generated-index" - } - } \ No newline at end of file diff --git a/docs/day-16/function-overloading.md b/docs/day-16/function-overloading.md deleted file mode 100644 index 0389f23a6..000000000 --- a/docs/day-16/function-overloading.md +++ /dev/null @@ -1,68 +0,0 @@ ---- -sidebar_position: 1 -title: "Function Overloading in C++" -description: "Function overloading is a feature of object-oriented programming where two or more functions can have the same name but different parameters." -sidebar_label: "Function Overloading" -slug: function-overloading-in-cpp ---- - -# Function Overloading in C++ - -Function overloading is a feature of object-oriented programming (OOP) where two or more functions can have the same name but different parameters. It allows you to define multiple functions with the same name within the same scope, as long as their parameter lists are different in terms of number, type, or both. - -## Why Use Function Overloading? -1. **Code Readability:** Function overloading can make your code more readable by using the same name for similar operations. For example, you can have multiple calculateArea() functions, each accepting different parameters (e.g., radius, length and width, base and height). - -2. **Convenience:** It provides a convenient way to define functions that perform similar operations on different types or numbers of arguments without having to invent new function names. - -## How Function Overloading Works? -Function overloading works based on the signature of the function, which includes the function name and the parameter list. The compiler distinguishes between overloaded functions by looking at the number, types, and order of the parameters. - -Example of Function Overloading - ```cpp - #include <iostream> - using namespace std; - - // Function to add two integers - int add(int a, int b) { - return a + b; - } - - // Function to add three integers - int add(int a, int b, int c) { - return a + b + c; - } - - // Function to add two doubles - double add(double a, double b) { - return a + b; - } - - int main() { - cout << "Sum of 2 and 3 is: " << add(2, 3) << endl; - cout << "Sum of 2, 3, and 4 is: " << add(2, 3, 4) << endl; - cout << "Sum of 2.5 and 3.5 is: " << add(2.5, 3.5) << endl; - return 0; - } - ``` - -In this example, the add function is overloaded three times. The compiler determines which version of add to call based on the number and types of arguments provided. - -## Rules for Function Overloading -1. **Function Signature:** Overloaded functions must differ in the number or types of their parameters. Return type alone is not sufficient to differentiate functions. - -2. **Scope:** Function overloading is only applicable within the same scope. You cannot overload functions from different scopes, such as functions in different namespaces. - -3. **Default Arguments:** Default arguments can be used in overloaded functions, but they do not participate in distinguishing between overloaded functions. - -4. **Function Templates:** Function templates can also be overloaded, allowing you to define generic functions that can operate on different types. - -## Functions that cannot be overloaded in C++ -1. Functions with different return types cannot be overloaded. -2. Static member functions with the same name and parameter types cannot be overloaded. -3. Parameters declared as arrays are adjusted to pointers, so functions cannot be overloaded based on array versus pointer types. -4. Functions cannot be overloaded based on whether a parameter is a function type or a pointer to the same function type. -5. Functions cannot be overloaded based on const and/or volatile qualifiers on parameters, as these qualifiers are ignored when determining the function being declared, defined, or called. - -## Conclusion -Function overloading is a powerful feature in C++ that allows you to define multiple functions with the same name, providing flexibility and readability to your code. By carefully designing overloaded functions, you can create more intuitive and expressive interfaces for your classes and functions. \ No newline at end of file diff --git a/docs/day-16/operator-overloading.md b/docs/day-16/operator-overloading.md deleted file mode 100644 index 390fc4903..000000000 --- a/docs/day-16/operator-overloading.md +++ /dev/null @@ -1,67 +0,0 @@ ---- -sidebar_position: 2 -title: "Operator Overloading in C++" -description: "Operator overloading is a compile-time polymorphism. It is an idea of giving special meaning to an existing operator in C++ without changing its original meaning." -sidebar_label: "Operator Overloading" -slug: operator-overloading-in-cpp ---- - -# Operator Overloading in C++ - -Operator overloading is a feature of C++ that allows you to redefine the meaning of operators when they are used with user-defined types (classes or structures). It is a form of compile-time polymorphism, where the same operator can be used to perform different operations depending on the context in which it is used. - -## Why Use Operator Overloading? -1. **Natural Syntax:** Operator overloading allows you to use operators with user-defined types in a way that is natural and intuitive, similar to built-in types. - -2. **Code Readability:** It can make your code more readable and expressive by allowing you to use operators to perform operations that are meaningful for your custom types. - -3. **Consistency:** Operator overloading can help maintain consistency in your code by allowing you to use operators in a uniform way across different types. - -# How Operator Overloading Works? - -Operator overloading works by defining a function that is called when an operator is used with an object of a class or structure. The syntax for overloading an operator is to define a function with the keyword operator followed by the operator you want to overload. - -For example, to overload the + operator for adding two objects of a class: - ```cpp - class Vector { - private: - int x, y; - public: - Vector(int x, int y) : x(x), y(y) {} - Vector operator+(const Vector& other) { - return Vector(x + other.x, y + other.y); - } - }; - - int main() { - Vector v1(1, 2); - Vector v2(3, 4); - Vector v3 = v1 + v2; // Calls the overloaded + operator - return 0; - } - ``` - -## Rules for Operator Overloading - -1. **Precedence and Associativity:** You cannot change the precedence or associativity of operators through overloading. - -2. **Number of Operands:** You cannot change the number of operands an operator takes. For example, you cannot overload the + operator to take three operands. - -3. **Syntax:** The syntax for overloading operators is fixed and cannot be changed. For example, you cannot change the syntax for the + operator to use a different symbol. - -4. **Semantics:** While you can change the meaning of an operator, it is important to maintain consistency with the standard meaning of the operator to avoid confusion. - -## Commonly Overloaded Operators -1. Arithmetic operators: - `+`, `-`, `*`, `/`, `%` -2. Relational operators: - `<`, `<=`, `>`, `>=`, `==`, `!=` -3. Increment and decrement operators: - `++`, `--` -4. Stream insertion and extraction operators: - `<<`, `>>` -5. Assignment operators: - `=`, `+=`, `-=`, `*=`, `/=`, `%=` - -## Conclusion -Operator overloading is a powerful feature in C++ that allows you to redefine the behavior of operators for user-defined types. By carefully designing overloaded operators, you can make your code more expressive and easier to understand, leading to more maintainable and robust software. \ No newline at end of file diff --git a/docs/day-18/Linked-List-in-cpp.md b/docs/day-18/Linked-List-in-cpp.md deleted file mode 100644 index 702cc8a85..000000000 --- a/docs/day-18/Linked-List-in-cpp.md +++ /dev/null @@ -1,74 +0,0 @@ ---- -sidebar_position: 2 -title: "Linked List in C++" -description: "In this tutorial we will learn about Linked List in C++." -sidebar_label: "Linked List in C++" -slug: Linked-List-in-cpp ---- -# Linked List in C++ -Linked list is a **liner data structure** which stores data in **non-contiguous memory** locations.It has nodes which consist of data and pointer. The data contains the value that you want to add and pointer contains the address to the next node. -### Representation of a Node in the Linked List -``` -struct Node{ - int data; - Node* next; -} -``` -`Data` : Values to be stored.\ -`Next` : Pointer to next node. - -As you cannot access the linked list using index, so we have a `head` which stores the address of the start of the linked list. - -## Types of Linked List -There are several types of linked list : -1. **Singly Linked List**.\ -In singly linked list there is only one pointer which points to the next node and the last node points to null. To access or print out the list, you start at the head and move from node to node by following each node’s next pointer. -<br></br> -![Singly Linked List](../../static/img/day-18/Sinlgy.png "Sinlgy linked list") -<br></br> - -2. **Doubly Linked List**\ -In doubly linked list we have three components inside the node. These are data, next pointer and previous pointer. This is advances version of singly linked list as this structure allows traversal of the list in both directions, making operations like insertion and deletion more efficient near both ends of the list, as you can easily access the previous node.<br></br> -![Doubly Linked List](../../static/img/day-18/Doubly.jpeg "Doubly linked list") -<br></br> - -3. **Circular Linked List**\ -In this type of linked list, the nodes are connected together in circular form thus there is no node pointing to NULL. Each node points to the next node and the last node points back to the first node, forming a single circle. -<br></br> -![Circular Linked List](../../static/img/day-18/Circular.jpeg "Circular linked list") -<br></br> - -4. **Circular Doubly Linked List** -This linked list is a combination of Doubly linked list and Circular linked list. In this also we have three components of node. The data contains the value, next contains pointer to next node and prev points to previous node.The last node’s next pointer points to the first node, and the first node’s previous pointer points to the last node, creating a circular doubly linked structure. This allows for traversal in both directions indefinitely.<br></br> -![Circular Doubly Linked List](../../static/img/day-18/DoublyCircular.jpeg "Circular Doubly linked list") -<br></br> - -## Applications of Linked Lists : -Some of the applictaions of linked list are as follow : -- **Implementation of stacks and queues:** Linked can be used for efficient insertion and deletion. -- **Hash table :** Linked list can prevent collisions in hash tables by chaining. -- **Graphs :** Adjacency lists for graphs are often represented with linked lists. -- **Dynamic Memory Allocation :** Used in the implementation of memory management schemes. -- **Web Browsers :** Linked lists are used in web browsers to keep track of the history of visited web pages. -- **Music and Image Viewers :** For previous and next functionalities. - -## Advantages of Linked List -Linked lists offer several advantages over other data structures like arrays. Here are some key benefits: - -- **Dynamic Size :** Unlike arrays, linked lists are dynamic and can grow or shrink in size. -- **Ease of Insertion/Deletion :** Addition or removal of elements doesn’t require shifting elements, as in arrays. -- **No Memory Wastage :** They allocate memory as needed, so there’s no unused memory. -- **No Size Limitation :** You’re not limited by an initial size declaration, unlike static arrays. -- **Implementation of Advanced Structures :** Useful in implementing stacks, queues, graphs, etc. -## Disadvantages of Linked List -While linked lists have several advantages, they also come with some drawbacks : - -- **Memory Usage :** Each node requires extra memory for a pointer, which can be significant for large lists. -- **Traversal :** Direct access is not possible; you must traverse the list from the beginning to reach a particular element. -- **Reverse Traversing :** In singly linked lists, reverse traversing is not possible without extra space for back pointers. -- **Complexity :** Operations like sorting and searching can be more complex and less efficient than with arrays. - - - - - diff --git a/docs/day-18/Operations-on-linked-list.md b/docs/day-18/Operations-on-linked-list.md deleted file mode 100644 index d84d02282..000000000 --- a/docs/day-18/Operations-on-linked-list.md +++ /dev/null @@ -1,210 +0,0 @@ ---- -sidebar_position: 2 -title: "Operations on Linked List" -description: "In this tutorial we will learn about operations performed on Linked List in C++." -sidebar_label: "Operations on Linked List" -slug: Operations-on-linked-list ---- -# Linked List Operations in C++ -Some basic operations that can be performed on Linked List are as follows: -- **Traversing :** Accessing each node of the list sequentially. -- **Seraching :** Finding a node with a given value. -- **Insertion :** Adding a new node to the list (at the beginning, end, or after/before a specific node). -- **Deletion :** Removing a node from the list (at the beginning, end, or after/before a specific node). - -## Traversal in Linked List -Traversal in a linked list refers to the process of going through each node, starting from the head, and accessing the data it contains. In C++, this is typically done using a loop that follows the next pointers of the nodes until it reaches the end of the list (null pointer). \ -### Code -``` -node* temp = head; - -cout<<"Elements are "<<endl; - -while(temp != NULL) { - - cout<<temp->data<<endl; - temp = temp->next; - -} - -``` -By the above code we can display all the elements present in linked list. -### Output -``` -Elements are -1 -2 -3 -``` - -## Searching in Linked List -Seraching can pe done with tarversal. You can loop until temp reaches the last node and if the values is found jump out of loop and print it. -### Code -``` -Node* temp = head; - - while (temp != NULL) { - - if (temp>data == key) - return true; - - temp = temp->next; - - } - - return false; - ``` - -## Insertion in a Linked List - -Insertion is performed at three different places. -- ### **At the beginning** -When you have to insert a value at the beginning of the linked list. - - Create a new node with the given data. - - Make the new node’s next pointer point to the current head of the list. - - Update the head of the list to be the new node. - -### Code -``` -oid insertAtStart(Node** head, int newData) { - // Step 1: Allocate new node - Node* newNode = new Node(); - newNode->data = newData; - - // Step 2: Make next of new node as head - newNode->next = *head; - - // Step 3: Move the head to point to the new node - *head = newNode; -} - -``` - -- ### **At a particluar position.** - - Find the previous node of the desired position. - - Create a new node with the given data. - - Set the new node’s next pointer to the next pointer of the previous node. - - Update the previous node’s next pointer to point to the new node - -### Code -``` -oid insertAtPosition(Node** head, int position, int newData) { - // Step 1: Allocate new node - Node* newNode = new Node(); - newNode->data = newData; - - // Start from the head - Node* temp = *head; - - // Find previous node of the desired position - for(int i = 1; temp != nullptr && i < position - 1; i++) { - temp = temp->next; - } - - // If position is more than number of nodes - if (temp == nullptr || temp->next == nullptr) { - return; - } -} -``` - -- ### **At the end.** - - Create a new Node - - Check if the linked list is empty. If yes then add new node as head. - - Else traverse till the last node of the linked list. - - Update the next pointer of the last node from NULL to new node. - -### Code -``` -void insertAtEnd(Node** head, int newData) { - // Step 1: Allocate new node - Node* newNode = new Node(); - newNode->data = newData; - newNode->next = nullptr; - - // If the Linked List is empty, then make the new node as head - if (*head == nullptr) { - *head = newNode; - return; - } - - // Else traverse till the last node - Node* last = *head; - while (last->next != nullptr) { - last = last->next; - } - - // Step 2 & 3: Change the next of last node - last->next = newNode; -} -``` -## Deletion in Linked List -Deletion can also be performed in different ways: -- ### **At the beginning** - - Check if the list is not empty. - - Store the head node in a temporary variable. - - Update the head to point to the next node. - - Delete the temporary node. -### Code -``` -void deleteAtStart(Node** head) { - // If linked list is empty - if (*head == nullptr) return; - - // Store head node - Node* temp = *head; - - // Move the head pointer to the next node - *head = temp->next; - - // Delete the old head node - delete temp; -} -``` - -- ### **At a particular position** - - Find the previous node of the node to be deleted. - - Change the next pointer of the previous node. - - Delete the node -### Code -``` -void deleteAtPosition(Node** head, int position) { - if (*head == nullptr) return; - - Node* temp = *head; - - for (int i = 1; temp != nullptr && i < position - 1; i++) - temp = temp->next; - - if (temp == nullptr || temp->next == nullptr) - return; - Node *next = temp->next->next; - delete temp->next; - temp->next = next; -} -``` - -- ### **At the end** - - Check if the list is not empty. - - If there’s only one node, delete it and update the head to null. - - Otherwise, find the second-to-last node. - - Delete the last node and update the second-to-last node’s next pointer to null. -### Code -``` -void deleteAtEnd(Node** head) { - if (*head == nullptr || (*head)->next == nullptr) { - delete *head; - *head = nullptr; - return; - } - Node* temp = *head; - while (temp->next->next != nullptr) - temp = temp->next; - delete temp->next; - - temp->next = nullptr; -} -``` - - - diff --git a/docs/day-18/_category_.json b/docs/day-18/_category_.json deleted file mode 100644 index 75a4c7aec..000000000 --- a/docs/day-18/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 18", - "position": 18, - "link": { - "type": "generated-index" - } - } \ No newline at end of file diff --git a/docs/day-19/_category_.json b/docs/day-19/_category_.json deleted file mode 100644 index afb32dec5..000000000 --- a/docs/day-19/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 19", - "position": 20, - "link": { - "type": "generated-index" - } -} diff --git a/docs/day-19/examples.md b/docs/day-19/examples.md deleted file mode 100644 index bc44ea7ed..000000000 --- a/docs/day-19/examples.md +++ /dev/null @@ -1,146 +0,0 @@ ---- -sidebar_position: 3 -title: "Examples" -description: "In this tutorial, we will see some examples and real world applications related to Polymorphism in c++." -sidebar_label: "Examples" -slug: examples-in-cpp ---- - -Image -[examples](C:\Users\Shruti\OneDrive\Desktop\30-Days-Of-CPP\static\img\day-19\poly3.png) - -## Real-world Applications of Polymorphism - -1. GUI Frameworks -Graphical User Interface (GUI) frameworks extensively use polymorphism. Different types of UI elements (buttons, text boxes, labels) inherit from a common base class and override methods like draw or handleEvent. - -Example Code- - -#include <iostream> -using namespace std; - -class UIElement { -public: - virtual void draw() = 0; // Pure virtual function -}; - -class Button : public UIElement { -public: - void draw() override { - cout << "Drawing a button" << endl; - } -}; - -class TextBox : public UIElement { -public: - void draw() override { - cout << "Drawing a text box" << endl; - } -}; - -void renderUI(UIElement *element) { - element->draw(); -} - -int main() { - Button btn; - TextBox txtBox; - - renderUI(&btn); // Output: Drawing a button - renderUI(&txtBox); // Output: Drawing a text box - - return 0; -} - -2. File Systems -In file systems, different file types (text files, binary files, image files) can inherit from a base File class and override methods like open, read, write, and close. - -Example Code- -#include <iostream> -using namespace std; - -class File { -public: - virtual void open() = 0; - virtual void close() = 0; -}; - -class TextFile : public File { -public: - void open() override { - cout << "Opening text file" << endl; - } - - void close() override { - cout << "Closing text file" << endl; - } -}; - -class BinaryFile : public File { -public: - void open() override { - cout << "Opening binary file" << endl; - } - - void close() override { - cout << "Closing binary file" << endl; - } -}; - -void manageFile(File *file) { - file->open(); - // Perform file operations - file->close(); -} - -int main() { - TextFile txt; - BinaryFile bin; - - manageFile(&txt); // Output: Opening text file, Closing text file - manageFile(&bin); // Output: Opening binary file, Closing binary file - - return 0; -} - -3. Game Development -In game development, different game entities (player, enemies, NPCs) inherit from a common Entity base class and override methods like update, render, and interact. - -Example Code- - -#include <iostream> -using namespace std; - -class Entity { -public: - virtual void update() = 0; -}; - -class Player : public Entity { -public: - void update() override { - cout << "Updating player" << endl; - } -}; - -class Enemy : public Entity { -public: - void update() override { - cout << "Updating enemy" << endl; - } -}; - -void gameLoop(Entity *entity) { - entity->update(); - // Other game loop operations -} - -int main() { - Player player; - Enemy enemy; - - gameLoop(&player); // Output: Updating player - gameLoop(&enemy); // Output: Updating enemy - - return 0; -} diff --git a/docs/day-19/polymorphism.md b/docs/day-19/polymorphism.md deleted file mode 100644 index fd8c7a012..000000000 --- a/docs/day-19/polymorphism.md +++ /dev/null @@ -1,26 +0,0 @@ ---- -sidebar_position: 1 -title: "Polymorphism in C++" -description: "In this tutorial, we will learn about Polymorphism in C++ programming with the help of examples." -sidebar_label: "Polymorphism" -slug: polymorphism-in-cpp ---- - -## What is Polymorphism? -The word “polymorphism” means having many forms. In simple words, we can define polymorphism as the ability of a message to be displayed in more than one form. A real-life example of polymorphism is a person who at the same time can have different characteristics. A man at the same time is a father, a husband, and an employee. So the same person exhibits different behavior in different situations. This is called polymorphism. Polymorphism is considered one of the important features of Object-Oriented Programming. - -Image -[Polymorphism](C:\Users\Shruti\OneDrive\Desktop\30-Days-Of-CPP\static\img\day-19\poly1.png) - -## Types of Polymorphism- -1) Compile-time Polymorphism- This type of polymorphism is achieved by function overloading or operator overloading. -2) Runtime Polymorphism- This type of polymorphism is achieved by Function Overriding. Late binding and dynamic polymorphism are other names for runtime polymorphism. The function call is resolved at runtime in runtime polymorphism. - -## Advantages of Polymorphism -Polymorphism in C++ allows for: - -1) Code reusability: Write code that works with objects of different classes. -2) Method overriding: Redefine base class methods in derived classes. -3) Dynamic binding: Decide at runtime which method to invoke. -4) Abstract interfaces: Define interfaces for different classes to implement. - diff --git a/docs/day-19/types-of-polymorphism.md b/docs/day-19/types-of-polymorphism.md deleted file mode 100644 index c59907fc4..000000000 --- a/docs/day-19/types-of-polymorphism.md +++ /dev/null @@ -1,174 +0,0 @@ ---- -sidebar_position: 2 -title: "Types of Polymorphism in C++" -description: "In this tutorial, we will learn about Types of Polymorphism in C++ programming with the help of examples." -sidebar_label: "Types of Polymorphism" -slug: Types-of-Polymorphism ---- -## Types of Polymorphism -There are two types of polymorphism namely- Compile time Polymorphism and Run Time Polymorphism - -Image -[Types of Polymorphism](C:\Users\Shruti\OneDrive\Desktop\30-Days-Of-CPP\static\img\day-19\poly2.png) - -## Compile Time Polymorphism -Compile-time polymorphism, also known as static polymorphism, occurs when the method or function to be invoked is determined at compile time. This is primarily achieved through method overloading and operator overloading. - -Method Overloading- -Method overloading allows a class to have more than one method with the same name, as long as their parameter lists are different. The difference can be in the number of parameters, the type of parameters, or both. - -Example- -class Calculator { - // Method with 2 integer parameters - public int add(int a, int b) { - return a + b; - } - - // Method with 3 integer parameters - public int add(int a, int b, int c) { - return a + b + c; - } - - // Method with 2 double parameters - public double add(double a, double b) { - return a + b; - } - - // Method with 3 double parameters - public double add(double a, double b, double c) { - return a + b + c; - } -} - -public class Main { - public static void main(String[] args) { - Calculator calc = new Calculator(); - System.out.println(calc.add(5, 10)); // Output: 15 - System.out.println(calc.add(5, 10, 15)); // Output: 30 - System.out.println(calc.add(5.5, 10.5)); // Output: 16.0 - System.out.println(calc.add(5.5, 10.5, 15.5)); // Output: 31.5 - } -} - -Operator Overloading- -Operator overloading allows developers to redefine the behavior of operators for user-defined types. While not commonly supported in many mainstream OOP languages (e.g., Java), languages like C++ allow it. - -Example- -#include <iostream> -using namespace std; - -class Complex { -private: - float real; - float imag; -public: - Complex() : real(0), imag(0) {} - Complex(float r, float i) : real(r), imag(i) {} - - // Overloading the + operator - Complex operator + (const Complex &c) { - Complex result; - result.real = real + c.real; - result.imag = imag + c.imag; - return result; - } - - void display() { - cout << real << " + " << imag << "i" << endl; - } -}; - -int main() { - Complex c1(3.0, 4.0); - Complex c2(1.0, 2.0); - Complex c3; - - c3 = c1 + c2; // Using the overloaded + operator - - c3.display(); // Output: 4.0 + 6.0i - - return 0; -} - -## Runtime Polymorphism -Runtime polymorphism, also known as dynamic polymorphism, occurs when a call to an overridden method is resolved at runtime rather than compile time. This is primarily achieved through method overriding, where a subclass provides a specific implementation of a method that is already defined in its superclass. Runtime polymorphism allows a method to behave differently based on the object that invokes it, providing flexibility and enabling more dynamic and extensible code. - -Method Overriding- -Method overriding is when a subclass provides a specific implementation for a method that is already defined in its superclass. The overridden method in the subclass should have the same name, return type, and parameter list as the method in the superclass. - -Example- -class Animal { - void sound() { - System.out.println("Animal makes a sound"); - } -} - -class Dog extends Animal { - // Overriding the sound method - @Override - void sound() { - System.out.println("Dog barks"); - } -} - -class Cat extends Animal { - // Overriding the sound method - @Override - void sound() { - System.out.println("Cat meows"); - } -} - -public class Main { - public static void main(String[] args) { - Animal myAnimal; - - myAnimal = new Dog(); - myAnimal.sound(); // Output: Dog barks - - myAnimal = new Cat(); - myAnimal.sound(); // Output: Cat meows - } -} - -Dynamic Method Dispatch- -Dynamic method dispatch is the mechanism by which a call to an overridden method is resolved at runtime. This process allows a superclass reference variable to refer to a subclass object and call the overridden method of the subclass. - -Example -class Vehicle { - void run() { - System.out.println("Vehicle is running"); - } -} - -class Car extends Vehicle { - @Override - void run() { - System.out.println("Car is running"); - } -} - -class Bike extends Vehicle { - @Override - void run() { - System.out.println("Bike is running"); - } -} - -public class Main { - public static void main(String[] args) { - Vehicle myVehicle; - - myVehicle = new Car(); - myVehicle.run(); // Output: Car is running - - myVehicle = new Bike(); - myVehicle.run(); // Output: Bike is running - } -} - -## Advantages of Runtime Polymorphism - -1) Flexibility and Extensibility: Allows new classes to be added with minimal changes to existing code. -2) Code Reusability: Enables code to be written more generically, which can handle new objects as they are added. -3) Dynamic Behavior: Provides the ability to write code that can behave differently based on the object that invokes it, allowing for more dynamic and flexible applications. \ No newline at end of file diff --git a/docs/day-20/Big_Five_In_OOP.md b/docs/day-20/Big_Five_In_OOP.md deleted file mode 100644 index 14899b231..000000000 --- a/docs/day-20/Big_Five_In_OOP.md +++ /dev/null @@ -1,231 +0,0 @@ ---- -sidebar_position: 2 -title: "The Big Five in C++" -description: "Understand the Big Five in C++ OOP: default constructor, destructor, copy constructor, copy assignment operator, and move constructor." -sidebar_label: "The Big Five" -slug: the-big-five-in-cpp ---- - -# The Big Five in C++ - -The Big Five in C++ are essential to managing resources and object lifetimes in Object-Oriented Programming (OOP). These include the default constructor, destructor, copy constructor, copy assignment operator, and move constructor. Understanding these concepts is crucial for writing efficient and robust C++ code. - -## Introduction to the Big Five -In C++, the Big Five are special member functions that control the creation, copying, and destruction of objects. They play a critical role in resource management, especially when dealing with dynamic memory allocation, file handles, and other resources that need explicit handling. -<img src="https://github.com/Salma-Mamdoh/30-Days-Of-CPP/blob/main/static/img/day-20/Big%20Five%20in%20OOP.jpg" alt="C++ deep copying and shallow copying"> - -## Default Constructor -### Definition -The default constructor initializes objects when no arguments are provided. If no constructor is defined, the compiler provides a default constructor. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Example { -public: - int value; - - // Default constructor - Example() : value(0) { - cout << "Default constructor called." << endl; - } -}; - -int main() { - Example obj; // Default constructor is called - cout << "Value: " << obj.value << endl; - - return 0; -} -``` -In this example, the default constructor initializes `value` to `0`. - -## Destructor -### Definition -The destructor cleans up resources when an object goes out of scope or is explicitly deleted. The compiler automatically provides a destructor if none is defined. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Example { -public: - int* data; - - Example(int value) { - data = new int(value); - } - - // Destructor - ~Example() { - delete data; - cout << "Destructor called, memory freed." << endl; - } -}; - -int main() { - Example obj(42); // Constructor allocates memory - cout << "Value: " << *obj.data << endl; - - return 0; // Destructor is called here -} -``` -In this example, the destructor ensures that dynamically allocated memory is freed. - -## Copy Constructor -### Definition -The copy constructor creates a new object as a copy of an existing object. It is invoked when an object is passed by value, returned by value, or explicitly copied. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Example { -public: - int* data; - - Example(int value) { - data = new int(value); - } - - // Copy constructor - Example(const Example& source) { - data = new int(*source.data); - cout << "Copy constructor called." << endl; - } - - ~Example() { - delete data; - cout << "Destructor called, memory freed." << endl; - } -}; - -int main() { - Example obj1(42); - Example obj2 = obj1; // Copy constructor is called - - cout << "Value in obj1: " << *obj1.data << endl; - cout << "Value in obj2: " << *obj2.data << endl; - - return 0; -} -``` -In this example, the copy constructor creates a deep copy of the data. - -## Copy Assignment Operator -### Definition -The copy assignment operator assigns the values from one object to another existing object. It is invoked when an object is assigned to another using the `=` operator. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Example { -public: - int* data; - - Example(int value) { - data = new int(value); - } - - // Copy assignment operator - Example& operator=(const Example& source) { - if (this == &source) { - return *this; // Self-assignment check - } - - delete data; // Free existing resource - data = new int(*source.data); // Allocate new resource - cout << "Copy assignment operator called." << endl; - - return *this; - } - - ~Example() { - delete data; - cout << "Destructor called, memory freed." << endl; - } -}; - -int main() { - Example obj1(42); - Example obj2(0); - obj2 = obj1; // Copy assignment operator is called - - cout << "Value in obj1: " << *obj1.data << endl; - cout << "Value in obj2: " << *obj2.data << endl; - - return 0; -} -``` -In this example, the copy assignment operator ensures proper resource management by freeing existing resources and allocating new ones. - -## Move Constructor and Move Assignment Operator -### Definition -The move constructor and move assignment operator transfer resources from a temporary object (rvalue) to a new object, improving performance by avoiding unnecessary deep copies. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Example { -public: - int* data; - - Example(int value) { - data = new int(value); - } - - // Move constructor - Example(Example&& source) noexcept : data(source.data) { - source.data = nullptr; - cout << "Move constructor called." << endl; - } - - // Move assignment operator - Example& operator=(Example&& source) noexcept { - if (this == &source) { - return *this; // Self-assignment check - } - - delete data; // Free existing resource - data = source.data; // Steal resource - source.data = nullptr; - cout << "Move assignment operator called." << endl; - - return *this; - } - - ~Example() { - delete data; - cout << "Destructor called, memory freed." << endl; - } -}; - -int main() { - Example obj1(42); - Example obj2 = move(obj1); // Move constructor is called - - cout << "Value in obj2: " << *obj2.data << endl; - - return 0; -} -``` -In this example, the move constructor transfers ownership of `data` to `obj2`, leaving `obj1` in a valid but unspecified state. - -## Rules of Three, Five, and Zero -### Explanation and Best Practices -- **Rule of Three:** If a class requires a user-defined destructor, copy constructor, or copy assignment operator, it likely requires all three. -- **Rule of Five:** If a class requires a user-defined destructor, copy constructor, copy assignment operator, move constructor, or move assignment operator, it likely requires all five. -- **Rule of Zero:** Strive to design classes that do not require user-defined copy/move operations by utilizing smart pointers and other RAII (Resource Acquisition Is Initialization) techniques. - -## Conclusion -The Big Five in C++ are fundamental for managing object lifetimes and resources effectively. By understanding and properly implementing these special member functions, you can write more robust and efficient C++ code. - -Understanding these concepts helps in writing robust and efficient C++ code, especially when dealing with dynamic memory and other resources. diff --git a/docs/day-20/Deep_Copying_vs_Shallow_Copying.md b/docs/day-20/Deep_Copying_vs_Shallow_Copying.md deleted file mode 100644 index 171742ded..000000000 --- a/docs/day-20/Deep_Copying_vs_Shallow_Copying.md +++ /dev/null @@ -1,163 +0,0 @@ ---- -sidebar_position: 1 -title: "Deep Copying and Shallow Copying in C++" -description: "Understand the concepts of deep copying and shallow copying in C++, and learn how to implement them effectively." -sidebar_label: "Deep and Shallow Copying" -slug: deep-and-shallow-copying-in-cpp ---- - -# Deep Copying and Shallow Copying in C++ - -Deep copying and shallow copying are important concepts in C++ that deal with the duplication of objects. Understanding these concepts is crucial for managing resources, especially when dealing with dynamic memory allocation. - -## Introduction to Copying Objects -Copying objects in C++ involves creating a new instance of a class with the same values as an existing instance. There are two primary types of copying: -- **Shallow Copying:** Copies all member field values. If the field is a pointer, only the pointer is copied, not the data it points to. -- **Deep Copying:** Copies all fields and duplicates dynamically allocated memory pointed to by the fields, creating independent copies of the data. -<img src="https://github.com/Salma-Mamdoh/30-Days-Of-CPP/blob/main/static/img/day-20/Day-20-deep_copying_vs_Shallow_Copying.jpg" alt="C++ deep copying and shallow copying"> -## Shallow Copying -### Definition -Shallow copying duplicates an object's member fields, including pointers, but it does not copy the data pointed to by those pointers. This can lead to issues when dealing with dynamic memory allocation. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Shallow { -public: - int* data; - - Shallow(int value) { - data = new int(value); - } - - // Shallow copy constructor - Shallow(const Shallow& source) : data(source.data) { - cout << "Shallow copy constructor - shallow copy created." << endl; - } - - void displayData() { - cout << "Data: " << *data << endl; - } - - ~Shallow() { - delete data; - cout << "Destructor freeing data." << endl; - } -}; - -int main() { - Shallow obj1(42); - Shallow obj2 = obj1; // Shallow copy - - obj1.displayData(); - obj2.displayData(); - - return 0; -} -``` -In this example, both `obj1` and `obj2` point to the same memory location. When `obj2` is destructed, it will free the memory allocated to `data`, leading to a double-free error when `obj1` is destructed. - -### Issues with Shallow Copying -- **Double-Free Error:** Multiple objects trying to free the same memory. -- **Dangling Pointer:** One object may delete memory, leaving the other object with a pointer to non-existent memory. - -## Deep Copying -### Definition -Deep copying involves creating a new copy of the dynamically allocated memory pointed to by the object's fields. Each object has its own copy of the data, preventing the issues associated with shallow copying. - -### Example and Explanation -```cpp -#include <iostream> -using namespace std; - -class Deep { -public: - int* data; - - Deep(int value) { - data = new int(value); - } - - // Deep copy constructor - Deep(const Deep& source) { - data = new int(*source.data); - cout << "Deep copy constructor - deep copy created." << endl; - } - - void displayData() { - cout << "Data: " << *data << endl; - } - - ~Deep() { - delete data; - cout << "Destructor freeing data." << endl; - } -}; - -int main() { - Deep obj1(42); - Deep obj2 = obj1; // Deep copy - - obj1.displayData(); - obj2.displayData(); - - return 0; -} -``` -In this example, `obj1` and `obj2` have their own separate copies of `data`. Each object manages its own memory, preventing the issues of double-free and dangling pointers. - -## Implementing Deep Copy and Shallow Copy in C++ -### Shallow Copy Implementation -Shallow copies use the default copy constructor provided by the compiler. This constructor copies the member field values directly. - -### Deep Copy Implementation -To implement a deep copy, you need to define a custom copy constructor and assignment operator. -```cpp -class Deep { -public: - int* data; - - Deep(int value) { - data = new int(value); - } - - // Deep copy constructor - Deep(const Deep& source) { - data = new int(*source.data); - } - - // Deep copy assignment operator - Deep& operator=(const Deep& source) { - if (this == &source) { - return *this; // self-assignment check - } - delete data; // free existing resource - data = new int(*source.data); // allocate new resource - return *this; - } - - ~Deep() { - delete data; - } -}; -``` - -## Use Cases and Best Practices -### Shallow Copying -- Suitable for objects with no pointers or dynamic memory. -- Useful when performance is critical and data sharing is acceptable. - -### Deep Copying -- Necessary for objects with pointers to dynamically allocated memory. -- Prevents resource management issues like double-free and dangling pointers. - -### Best Practices -- Use shallow copying for simple objects and deep copying for complex objects. -- Always provide custom copy constructors and assignment operators for deep copying. -- Use smart pointers (e.g., `std::shared_ptr`, `std::unique_ptr`) to manage dynamic memory safely. - -## Conclusion -Deep copying and shallow copying are fundamental concepts in C++ for managing object duplication and memory allocation. Understanding these concepts helps in writing robust and efficient C++ code, especially when dealing with dynamic memory. - diff --git a/docs/day-20/_category_.json b/docs/day-20/_category_.json deleted file mode 100644 index 4245345ca..000000000 --- a/docs/day-20/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 20", - "position": 21, - "link": { - "type": "generated-index" - } - } \ No newline at end of file diff --git a/docs/day-20/image.png b/docs/day-20/image.png deleted file mode 100644 index c2a9f5e12..000000000 Binary files a/docs/day-20/image.png and /dev/null differ diff --git a/docs/day-20/practice-questions.md b/docs/day-20/practice-questions.md deleted file mode 100644 index ea2e2b708..000000000 --- a/docs/day-20/practice-questions.md +++ /dev/null @@ -1,299 +0,0 @@ ---- -sidebar_position: 1 -title: "Practice Question in C++" -description: "Function overloading is a feature of object-oriented programming where two or more functions can have the same name but different parameters." -sidebar_label: "Easy Problems in c++" -slug: practice-problems-in-cpp ---- - -# Easy Practice Problems in C++ - -Do you want to improve your command on C++ language? Explore our vast library of C++ exercise questions, which are specifically designed for beginners as well as for advanced programmers. We provide a large selection of coding exercises that cover every important topic, including classes, objects, arrays, matrices, and pointers. Master C++ with our practical approach and practice C++ exercises online - -![alt text](image.png) - -## C++ Exercise Problems -There are over 20+ C Exercise questions for you to practice along with the solutions to every question for a better understanding. You can solve these questions online in GeeksforGeeks IDE. - -**Q1. Write a Program to Print “Hello World” in the Console Screen.** -Write a simple program that prints the words “Hello World” on the console. - - -For Example, -``` -Output: Hello World -``` - -**Q2. Write a Program to Read and Print Number Input From the User.** -In this problem, you have to create a simple program that reads a number that is entered by the user and prints it on the console screen. - -For Example, - -``` -Input: Enter any Number: 25 - -Output: Entered Number: 25 -``` - -**Q3. Write a Program to Print the ASCII Value of a Character.** -In C++, each character has some ASCII value associated with it. In this problem, we have to print the ASCII value of the character in the console. - -For Example, -``` -Character = A - -Output: ASCII Value of 'A' = 65 -``` - -**Q4. Write a Program to Swap Two Numbers.** -You have to create a program that swaps the value of two number variables. It means that the value of the first variable will be stored in the second variable and the value of the second variable should be stored in the first variable. - -For Example, -```cpp -// Variables initally -a = 10, b = 250 - -// After execution -Output: a = 250, b = 10 -``` - -**Q5. Write a Program to Find the Size of int, float, double, and char.** -In C++, each datatype requires some memory to store data. In this program, you have to print the required memory (i.e. size in bytes) for int, float, double, and char data types on the console. - -For Example, -```cpp -Output -size of int: 10 bytes -size of float: 20 bytes -size of double: 30 bytes -size of char: 40 bytes -``` - -**Q6. Write a Program to Find Compound Interest.** -In this problem, you have to write a program that calculates and prints the compound interest for the given Principle, Rate of Interest, and Time. - -For Example, -```cpp -Principle = 25000 -Rate = 12% -Time = 5 Years - -Output: Compound Interest = 19058.54 -``` - -**Q7. Write a Program to Check Even or Odd Integers.** -In this problem, we have to simply check whether the given integer is odd or even and print the output on the console. - -For Example, -```cpp -Number = 28 - -Output: 28 is Even Number. -``` - -**Q8. Write a Program to Find the Largest Among 3 Numbers.** -In this problem, you are given 3 numbers, and you have to find out which one is the largest. - -For Example, -```cpp -Given Numbers: a = 10, b = 21 and c = 4 - -Output: b is the largest. -``` - -**Q9. Write a Program to Check if a Given Year Is a Leap Year.** -In this problem, you have to write a program that takes a year as an input, and then checks whether it is a leap year or not. - -For Example, -```cpp -Input: 2020 - -Output: 2020 is a Leap Year -``` - -**Q10. Write a Program to Check Whether a Number Is Prime or Not.** -The number can be prime or non-prime based on the number of its factors. In this program, we have to check whether the given number is prime or not and print the result on the console screen. - -For Example, -```cpp -Number to Check = 29 - -Output: 29 is a prime number. -``` - -**Q11. Write a Program to Check Whether a Number Is a Palindrome or Not.** -A palindrome number is a number that is equal to itself even after reversing its digits. In this program, we have to check for palindrome numbers. - -For Example, -```cpp -Number to Check = 1231 - -Output: 1231 is not a palindrome number. -``` - -**Q12. Write a Program to Make a Simple Calculator.** -In this problem, you have to make a program that can perform addition, subtraction, multiplication, and division on two numbers entered by the user. The type of arithmetic operation can also be selected by the user. - -For Example, -```cpp -Input: -Enter the Number: 10 25 -Enter a for addition, -s for substraction, -m for multiplication, -d for division. - -{{if m is entered}} - -Output: 250 -``` - -**Q13. Write a Program to Reverse a Sentence Using Recursion.** -In this program, you have to simply reverse the sentence stored as a string. - -For Example, -```cpp -Sentence = "Quick brown fox"; - -Output: xof nworb kciuQ -``` - -**Q14. Write a Program for Fibonacci Numbers Using Recursion.** -The Fibonacci Series is a mathematical sequence in which the next number is the sum of the last two numbers in the sequence. In this program, you will have to print the Nth number in the sequence using recursion. - -For Example, -```cpp -N = 12 - -Output: 144 -``` - -**Q15. Write a Program to Swap Two Numbers Using a Function.** -In this program, you have to swap the values of two variables using another function. - -For Example, -```cpp -// in main function -a = 10, b = 22 - -Output: a = 22, b = 10 -``` - -**Q16. Write a Program to Check if Two Arrays Are Equal or Not.** -An array is said to be equal if the elements at the given index are equal in both arrays. In this program, you have to take two arrays, and then check whether the two arrays are equal. - -For Example, -```cpp -arr1[] = {5, 8, 3} -arr2[] = {5, 8, 11, 2} - -Output: arr1[] and arr2[] are not equal. -``` - -**Q17. Write a Program to Calculate the Average of All the Elements Present in an Array.** -In this problem, you have to calculate the average of all the elements present in the array and print it on the console screen. - -For Example, -```cpp -arr[] = {10, 22, 45, 11} - -Output: Average = 24.5 -``` - -**Q18. Write a Program to Find the Maximum and Minimum in an Array.** -In this problem, you have to find both maximum(largest) and minimum(smallest) numbers in a numerical array. - -For Example, -```cpp -arr[] = {10, 12, 45, 48, 22, 18} - -Output: -Maximum = 48 -Minimum = 10 -``` - -**Q19. Write a Program to Search an Element in an Array (Linear Search).** -In this program, you have to search for the given element in an array. If the element is found, you will print the index of the element. The array is unsorted. - -For Example, -```cpp -arr[] = {10, 11, 7, 8, 2, 9}; -Element to be Searched: 19 - -Output: 19 not found in the arr[] -``` - -**Q20. Write a Program to Print the Array After It Is Right Rotated K Times.** -Array Rotation means shifting the elements n positions to left or right. In this problem, you will have to rotate the array in the right direction k number of times. - -For Example, -```cpp -arr[] = {10, 11, 7, 33, 5, 1}; -K = 3 - -Output: Array after rotation: {33, 5, 1, 10, 11, 7} -``` - -**Q21. Write a Program to Compute the Sum of Diagonals of a Matrix.** -In this problem, you have to calculate the Sum of both the diagonal elements of a matrix. Matrix are generally represented as 2D arrays. - -For Example, -```cpp -matrix = 1 2 3 - 4 5 6 - 7 8 9 -``` -Output: -```cpp -Principal Diagonal = 16 -Secondary Diagonal = 15 -``` - -**Q22. Write a Program to Rotate the Elements of a Matrix.** -We can rotate the matrix in two ways: clockwise and anticlockwise. In this problem, you have to rotate the elements of the matrix in the clockwise direction for K number of times. - -For Example, -```cpp -matrix = 1 2 3 - 4 5 6 - 7 8 9 -K = 2 -``` -Output: -```cpp -Matrix = 7 4 1 - 8 5 2 - 9 6 3 -``` - -**Q23. Write a Program to Find the Length of a String.** -The length of the string is the number of characters in a string except the NULL character. Write a simple program to find the length of a string and print it on the console. - -For Example, -```cpp -str = "Dhairyagothi" -``` -``` -Output: Length of str = 12 -``` - -**Q24. Write a Program to Compare Two Strings.** -In this problem, you have to write a program to compare two strings to check whether they are the same or not. - -For Examples, -```cpp -str1 = "Geeks" -str2 = "geeks" - -Output: str1 and str2 are not equal. -``` - -**Q25. Write a Program to Check if the String Is Palindrome.** -Similar to a palindrome number, a palindrome string is a string that is equal to its reverse. You have to write a program to check whether the given string is a palindrome string or not. - -For Example, -```cpp -str = "naman" - -Output: str is a palindrome string. -``` \ No newline at end of file diff --git a/docs/day-21/Lambda Expressions and Functional Programming copy.md b/docs/day-21/Lambda Expressions and Functional Programming copy.md deleted file mode 100644 index d7a7542be..000000000 --- a/docs/day-21/Lambda Expressions and Functional Programming copy.md +++ /dev/null @@ -1,155 +0,0 @@ ---- -sidebar_position: 1 -title: "Lambda Expressions in C++" -description: "In this tutorial, we will learn about lambda expressions in C++ with the help of examples. Lambda expressions provide a way to create anonymous functions, useful for functional programming in C++." -sidebar_label: "Lambda Expressions" -slug: lambda-expressions-in-cpp ---- - -## Introduction: - -Lambda expressions provide a way to create anonymous functions (i.e., functions without a name) in C++. They are particularly useful for short snippets of code that are passed to algorithms or used as callbacks. Functional programming, which emphasizes immutability and first-class functions, can be effectively implemented in C++ using lambda expressions and the standard library's functional utilities. - -![30-days-of-cpp-introduction](../../static/img/day-21/Lambda%20Function.jpg) - -#### 1. Lambda Expressions: - -A lambda expression in C++ allows you to define an inline function directly in the code where it is used. This is especially useful for short operations, such as those passed to algorithms. - - -#### 2. Syntax of Lambda Expressions: - -The basic syntax of a lambda expression is: -```cpp -[capture](parameters) -> return_type { body } -``` - -- **Capture**: Specifies which variables are captured from the surrounding scope. -- **Parameters**: The parameters passed to the lambda, similar to a regular function. -- **Return type**: (Optional) The return type of the lambda. It can often be inferred by the compiler. -- **Body**: The code that gets executed when the lambda is called. - -Example: -```cpp -auto add = [](int a, int b) -> int { - return a + b; -}; -std::cout << "Sum: " << add(2, 3) << std::endl; // Output: Sum: 5 -``` - -#### 3. Capturing Variables: - -Lambda expressions can capture variables from their enclosing scope. There are several ways to capture variables: -- **Capture by value**: `[x, y]` captures `x` and `y` by value. -- **Capture by reference**: `[&x, &y]` captures `x` and `y` by reference. -- **Capture all by value**: `[=]` captures all variables by value. -- **Capture all by reference**: `[&]` captures all variables by reference. -- **Mixed capture**: `[=, &x]` captures all variables by value except `x`, which is captured by reference. - -Example: -```cpp -int x = 10; -int y = 20; - -auto printSum = [x, y]() { - std::cout << "Sum: " << x + y << std::endl; -}; - -printSum(); // Output: Sum: 30 -``` - -#### 4. Using Lambdas with Standard Algorithms: - -Lambdas are particularly useful with the Standard Template Library (STL) algorithms. Here’s an example using `std::for_each`: - -```cpp -#include <algorithm> -#include <vector> -#include <iostream> - -int main() { - std::vector<int> numbers = {1, 2, 3, 4, 5}; - std::for_each(numbers.begin(), numbers.end(), [](int n) { - std::cout << n << " "; - }); - // Output: 1 2 3 4 5 - return 0; -} -``` - -#### 5. Lambdas as Callbacks: - -Lambdas can be used as callbacks for event handling or asynchronous operations. Here’s an example with a simple callback mechanism: - -```cpp -#include <iostream> -#include <functional> - -void performOperation(const std::function<void(int)>& callback) { - int result = 42; // Imagine this is the result of some operation - callback(result); -} - -int main() { - performOperation([](int result) { - std::cout << "Operation result: " << result << std::endl; - }); - // Output: Operation result: 42 - return 0; -} -``` - -#### 6. Practical Examples and Exercises: - -**Example 1: Sorting a Vector with a Lambda** - -```cpp -#include <algorithm> -#include <vector> -#include <iostream> - -int main() { - std::vector<int> numbers = {5, 2, 9, 1, 5, 6}; - - std::sort(numbers.begin(), numbers.end(), [](int a, int b) { - return a < b; - }); - - for (int n : numbers) { - std::cout << n << " "; - } - // Output: 1 2 5 5 6 9 - return 0; -} -``` - -**Example 2: Filtering Elements with `std::copy_if` and a Lambda** - -```cpp -#include <algorithm> -#include <vector> -#include <iostream> - -int main() { - std::vector<int> numbers = {1, 2, 3, 4, 5, 6, 7, 8, 9, 10}; - std::vector<int> evenNumbers; - - std::copy_if(numbers.begin(), numbers.end(), std::back_inserter(evenNumbers), [](int n) { - return n % 2 == 0; - }); - - for (int n : evenNumbers) { - std::cout << n << " "; - } - // Output: 2 4 6 8 10 - return 0; -} -``` - -**Exercises:** - -1. Write a lambda function to calculate the factorial of a number. -2. Use a lambda to transform a vector of integers by squaring each element. -3. Create a lambda that captures a local variable by reference and modifies it within the lambda. - - diff --git a/docs/day-21/Macros.md b/docs/day-21/Macros.md deleted file mode 100644 index 5b5dbc8c4..000000000 --- a/docs/day-21/Macros.md +++ /dev/null @@ -1,132 +0,0 @@ ---- -sidebar_position: 2 -title: "Macros in C++" -description: "Learn about macros in C++, their usage, and best practices with practical examples. Macros are powerful preprocessor directives that enable code substitution before compilation." -sidebar_label: "Macros in C++" -slug: macros-in-cpp ---- - -## Introduction: - -Macros in C++ are preprocessor directives that allow for code substitution before compilation. They are used to define constants, create inline functions, and conditionally include code segments. - -![macros-in-cpp-introduction](../../static/img/day-21/Macros%20in%20cpp.jpg) - -#### 1. Defining Constants with `#define`: - -Macros are commonly used to define constants that are substituted directly into the code. - -```cpp -#define PI 3.14159 - -#include <iostream> - -int main() { - std::cout << "Value of PI: " << PI << std::endl; - return 0; -} -``` - -#### 2. Function-like Macros: - -You can create macros that act like functions, allowing for parameterized code substitution. - -```cpp -#define SQUARE(x) ((x) * (x)) - -#include <iostream> - -int main() { - int num = 5; - std::cout << "Square of " << num << " is: " << SQUARE(num) << std::endl; - return 0; -} -``` - -#### 3. Conditional Compilation: - -Macros enable conditional compilation, where certain code segments are included or excluded based on defined conditions. - -```cpp -#define DEBUG_MODE - -#include <iostream> - -int main() { -#ifdef DEBUG_MODE - std::cout << "Debug mode is on" << std::endl; -#endif - std::cout << "Program running" << std::endl; - return 0; -} -``` - -#### 4. Include Guards: - -Include guards prevent multiple inclusions of the same header file, ensuring the contents are only included once per translation unit. - -```cpp -#ifndef MY_HEADER_H -#define MY_HEADER_H - -// Header file content - -#endif // MY_HEADER_H -``` - -#### 5. Best Practices and Considerations: - -- **Use sparingly**: Overuse of macros can lead to code maintenance issues. -- **Prefer `const` or `constexpr`**: Use `const` variables or `constexpr` for constants instead of macros where possible. -- **Parenthesize**: Always parenthesize macro arguments and the entire expression to avoid unintended side effects. - -#### 6. Practical Examples and Exercises: - -**Example 1: Sorting with a Macro** - -```cpp -#include <algorithm> -#include <vector> -#include <iostream> - -#define SORT_DESCENDING(vec) std::sort(vec.begin(), vec.end(), [](int a, int b) { return a > b; }) - -int main() { - std::vector<int> numbers = {5, 2, 9, 1, 5, 6}; - - SORT_DESCENDING(numbers); - - for (int n : numbers) { - std::cout << n << " "; - } - // Output: 9 6 5 5 2 1 - return 0; -} -``` - -**Example 2: Conditional Compilation** - -```cpp -#include <iostream> - -#define DEBUG_MODE - -int main() { -#ifdef DEBUG_MODE - std::cout << "Debug mode is on" << std::endl; -#else - std::cout << "Debug mode is off" << std::endl; -#endif - - std::cout << "Program running" << std::endl; - return 0; -} -``` - -**Exercises:** - -1. Define a macro to calculate the factorial of a number. -2. Implement a macro for checking if a number is even. -3. Create a macro that swaps two variables. - - diff --git a/docs/day-21/_category_.json b/docs/day-21/_category_.json deleted file mode 100644 index 5c0a67f80..000000000 --- a/docs/day-21/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 21", - "position": 21, - "link": { - "type": "generated-index" - } - } \ No newline at end of file diff --git a/docs/day-23/type_of_trees.md b/docs/day-23/type_of_trees.md deleted file mode 100644 index 7d9f9320c..000000000 --- a/docs/day-23/type_of_trees.md +++ /dev/null @@ -1,114 +0,0 @@ ---- -slug: types-of-trees -title: Types of Trees in C++ -authors: [chaitanya] -tags: ["30daysofcpp", "trees", "data-structures", "cpp", "tutorial"] ---- - -## Types of Trees in C++ - -### Introduction - -Trees are versatile data structures that can be used to represent various hierarchical relationships. There are several types of trees, each with its own properties and use cases. Understanding the different types of trees is essential for choosing the right structure for a specific problem. - -### Types of Trees - -1. **Binary Tree** -2. **Binary Search Tree (BST)** -3. **AVL Tree** -4. **Red-Black Tree** -5. **B-Tree** -6. **Trie** -7. **Segment Tree** -8. **Suffix Tree** - -### Binary Tree - -A binary tree is a tree data structure where each node has at most two children, referred to as the left child and the right child. - -<img src="https://upload.wikimedia.org/wikipedia/commons/f/f7/Binary_tree.svg" alt="Binary Tree" width="300" height="300"> - -#### Properties: -- Each node has at most two children. -- The left and right children are distinct. - -### Binary Search Tree (BST) - -A binary search tree is a binary tree with the additional property that the left child of a node contains a value less than the node's value, and the right child contains a value greater than the node's value. - -<img src="https://upload.wikimedia.org/wikipedia/commons/d/da/Binary_search_tree.svg" alt="Binary Search Tree" width="300" height="300"> - -#### Properties: -- The left subtree of a node contains only nodes with values less than the node's value. -- The right subtree of a node contains only nodes with values greater than the node's value. -- Both the left and right subtrees must also be binary search trees. - -### AVL Tree - -An AVL tree is a self-balancing binary search tree. In an AVL tree, the heights of the two child subtrees of any node differ by at most one. - -<img src="https://media.geeksforgeeks.org/wp-content/uploads/20221229121830/avl.png" alt="AVL Tree" width="300" height="300"> - -#### Properties: -- It is a binary search tree. -- The height difference between the left and right subtrees of any node is at most one. - -### Red-Black Tree - -A red-black tree is a kind of self-balancing binary search tree where each node has an extra bit for denoting the color of the node, either red or black. This helps ensure the tree remains balanced during insertions and deletions. - -<img src="https://upload.wikimedia.org/wikipedia/commons/6/66/Red-black_tree_example.svg" alt="Red-Black Tree" width="300" height="300"> - -#### Properties: -- Each node is either red or black. -- The root is always black. -- All leaves (NIL nodes) are black. -- If a red node has children, then the children are always black. -- Every path from a node to its descendant NIL nodes has the same number of black nodes. - -### B-Tree - -A B-tree is a self-balancing tree data structure that maintains sorted data and allows searches, sequential access, insertions, and deletions in logarithmic time. B-trees are generalizations of binary search trees in that a node can have more than two children. - -<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/3/34/B-tree.svg/1920px-B-tree.svg.png" alt="B-Tree" width="300" height="300"> - -#### Properties: -- All leaves are at the same level. -- A B-tree of order m can have a maximum of m-1 keys and m children. -- Internal nodes can have a variable number of child nodes within some pre-defined range. - -### Trie - -A trie, also called a prefix tree, is a kind of search tree used to store a dynamic set or associative array where the keys are usually strings. - -<img src="https://upload.wikimedia.org/wikipedia/commons/thumb/b/be/Trie_example.svg/1920px-Trie_example.svg.png" alt="Trie" width="300" height="300"> - -#### Properties: -- Used to store strings. -- Each node represents a common prefix of some strings. - -### Segment Tree - -A segment tree is a tree data structure used for storing intervals or segments. It allows querying which of the stored segments contain a given point. - -<img src="https://he-s3.s3.amazonaws.com/media/uploads/a0c7f90.jpg" alt="Segment Tree" width="300" height="300"> - -#### Properties: -- Used for storing intervals or segments. -- Each node represents an interval. - -### Suffix Tree - -A suffix tree is a compressed trie containing all the suffixes of the given text as their keys and positions in the text as their values. - -<img src="https://media.geeksforgeeks.org/wp-content/uploads/patternsearching1.png" alt="Suffix Tree" width="300" height="300"> - -#### Properties: -- Used to store all suffixes of a given string. -- Efficient for pattern matching. - -### Conclusion - -Understanding the different types of trees and their properties is crucial for selecting the right tree structure for your specific needs. Each type of tree has its own advantages and is suited for different kinds of applications. - ---- diff --git a/docs/day-25/_category_.json b/docs/day-25/_category_.json deleted file mode 100644 index 8bd518523..000000000 --- a/docs/day-25/_category_.json +++ /dev/null @@ -1,7 +0,0 @@ -{ - "label": "Day 25", - "position": 25, - "link": { - "type": "generated-index" - } - } \ No newline at end of file diff --git a/docs/day-25/medium-level-questions.md b/docs/day-25/medium-level-questions.md deleted file mode 100644 index 2fa07f8de..000000000 --- a/docs/day-25/medium-level-questions.md +++ /dev/null @@ -1,143 +0,0 @@ ---- -sidebar_position: 1 -title: "Medium Level Questions in C++" -description: "In this tutorial, we will practise medium level practise problems in C++ with the help of examples." -sidebar_label: "medium Practise questions" -slug: medium-practise-question-cpp ---- - - -## Here are 20 medium level C++ questions along with their solutions: - -1. Write a program to find the factorial of a number. - - **Input:** 5 - - **Output:** The factorial of 5 is 120. - -2. Implement a binary search algorithm. - - **Input:** Sorted array: [1, 3, 5, 7, 9], Target element: 7 - - **Output:** Element 7 found at index 3. - -3. Create a class to represent a bank account with deposit and withdrawal methods. - - **Input:** Account balance: $100, Deposit amount: $50 - - **Output:** Account balance after deposit: $150 - -4. Write a program to reverse a string. - - **Input:** "Hello, World!" - - **Output:** "!dlroW ,olleH" - -5. Implement a stack using a linked list. - - **Input:** Push elements: 10, 20, 30 - - **Output:** Stack: 30 -> 20 -> 10 - -6. Create a class to represent a rectangle with methods to calculate area and perimeter. - - **Input:** Length: 5, Width: 3 - - **Output:** Area: 15, Perimeter: 16 - -7. Write a program to check if a number is prime. - - **Input:** 7 - - **Output:** 7 is a prime number. - -8. Implement a queue using an array. - - **Input:** Enqueue elements: 10, 20, 30 - - **Output:** Queue: 10 -> 20 -> 30 - -9. Create a class to represent a student with methods to calculate average marks. - - **Input:** Marks: [80, 90, 70, 85] - - **Output:** Average marks: 81.25 - -10. Write a program to find the largest element in an array. - - **Input:** Array: [5, 10, 3, 8, 2] - - **Output:** The largest element is 10. - -11. Implement a binary tree data structure. - - **Input:** Insert elements: 10, 5, 15, 3, 7, 12, 20 - - **Output:** Tree: - 10 - / \ - 5 15 - / \ / \ - 3 7 12 20 - -12. Create a class to represent a car with methods to start and stop the engine. - - **Input:** None - - **Output:** Car engine started. Car engine stopped. - -13. Write a program to check if a string is a palindrome. - - **Input:** "racecar" - - **Output:** "racecar" is a palindrome. - -14. Implement a hash table data structure. - - **Input:** Insert key-value pairs: ("John", 25), ("Alice", 30), ("Bob", 35) - - **Output:** Hash table: - Index 0: ("John", 25) - Index 1: ("Alice", 30) - Index 2: ("Bob", 35) - -15. Create a class to represent a circle with methods to calculate area and circumference. - - **Input:** Radius: 5 - - **Output:** Area: 78.54, Circumference: 31.42 - -16. Write a program to sort an array using bubble sort. - - **Input:** Array: [5, 2, 8, 1, 9] - - **Output:** Sorted array: [1, 2, 5, 8, 9] - -17. Implement a linked list data structure. - - **Input:** Insert elements: 10, 20, 30 - - **Output:** Linked list: 10 -> 20 -> 30 - -18. Create a class to represent a book with methods to get and set the author and title. - - **Input:** Author: "John Doe", Title: "The Book" - - **Output:** Book details: Author: "John Doe", Title: "The Book" - -19. Write a program to find the sum of all elements in an array. - - **Input:** Array: [1, 2, 3, 4, 5] - - **Output:** The sum of all elements is 15. - -20. Implement a merge sort algorithm. - - **Input:** Array: [5, 2, 8, 1, 9] - - **Output:** Sorted array: [1, 2, 5, 8, 9] - - - -## **[check solution here](./solution.md "check solution")** - diff --git a/docs/day-25/solution.md b/docs/day-25/solution.md deleted file mode 100644 index bcfff983d..000000000 --- a/docs/day-25/solution.md +++ /dev/null @@ -1,790 +0,0 @@ -1. Write a program to find the factorial of a number. - -```cpp -#include <iostream> - -int factorial(int n) { - if (n == 0 || n == 1) { - return 1; - } - return n * factorial(n - 1); -} - -int main() { - int num; - std::cout << "Enter a number: "; - std::cin >> num; - int result = factorial(num); - std::cout << "The factorial of " << num << " is " << result << std::endl; - return 0; -} -``` - -2. Implement a binary search algorithm. - -```cpp -#include <iostream> -#include <vector> - -int binarySearch(const std::vector<int>& arr, int target) { - int left = 0; - int right = arr.size() - 1; - while (left <= right) { - int mid = left + (right - left) / 2; - if (arr[mid] == target) { - return mid; - } else if (arr[mid] < target) { - left = mid + 1; - } else { - right = mid - 1; - } - } - return -1; -} - -int main() { - std::vector<int> arr = {1, 3, 5, 7, 9}; - int target = 7; - int index = binarySearch(arr, target); - if (index != -1) { - std::cout << "Element " << target << " found at index " << index << std::endl; - } else { - std::cout << "Element not found" << std::endl; - } - return 0; -} -``` - -3. Create a class to represent a bank account with deposit and withdrawal methods. - -```cpp -#include <iostream> - -class BankAccount { -private: - double balance; - -public: - BankAccount(double initialBalance) { - balance = initialBalance; - } - - void deposit(double amount) { - balance += amount; - } - - void withdraw(double amount) { - if (amount <= balance) { - balance -= amount; - } else { - std::cout << "Insufficient balance" << std::endl; - } - } - - double getBalance() { - return balance; - } -}; - -int main() { - BankAccount account(100); - account.deposit(50); - std::cout << "Account balance after deposit: $" << account.getBalance() << std::endl; - account.withdraw(30); - std::cout << "Account balance after withdrawal: $" << account.getBalance() << std::endl; - return 0; -} -``` - -4. Write a program to reverse a string. - -```cpp -#include <iostream> -#include <string> - -std::string reverseString(const std::string& str) { - std::string reversedStr; - for (int i = str.length() - 1; i >= 0; i--) { - reversedStr += str[i]; - } - return reversedStr; -} - -int main() { - std::string str = "Hello, World!"; - std::string reversedStr = reverseString(str); - std::cout << "Reversed string: " << reversedStr << std::endl; - return 0; -} -``` - -5. Implement a stack using a linked list. - -```cpp -#include <iostream> - -class Node { -public: - int data; - Node* next; - - Node(int value) { - data = value; - next = nullptr; - } -}; - -class Stack { -private: - Node* top; - -public: - Stack() { - top = nullptr; - } - - void push(int value) { - Node* newNode = new Node(value); - if (top == nullptr) { - top = newNode; - } else { - newNode->next = top; - top = newNode; - } - } - - void pop() { - if (top == nullptr) { - std::cout << "Stack is empty" << std::endl; - } else { - Node* temp = top; - top = top->next; - delete temp; - } - } - - int peek() { - if (top == nullptr) { - std::cout << "Stack is empty" << std::endl; - return -1; - } else { - return top->data; - } - } - - bool isEmpty() { - return top == nullptr; - } -}; - -int main() { - Stack stack; - stack.push(10); - stack.push(20); - stack.push(30); - std::cout << "Stack: "; - while (!stack.isEmpty()) { - std::cout << stack.peek() << " -> "; - stack.pop(); - } - std::cout << "NULL" << std::endl; - return 0; -} -``` - -6. Create a class to represent a rectangle with methods to calculate area and perimeter. - -```cpp -#include <iostream> - -class Rectangle { -private: - double length; - double width; - -public: - Rectangle(double l, double w) { - length = l; - width = w; - } - - double calculateArea() { - return length * width; - } - - double calculatePerimeter() { - return 2 * (length + width); - } -}; - -int main() { - double length = 5; - double width = 3; - Rectangle rectangle(length, width); - double area = rectangle.calculateArea(); - double perimeter = rectangle.calculatePerimeter(); - std::cout << "Area: " << area << ", Perimeter: " << perimeter << std::endl; - return 0; -} -``` - -7. Write a program to check if a number is prime. - -```cpp -#include <iostream> - -bool isPrime(int num) { - if (num <= 1) { - return false; - } - for (int i = 2; i * i <= num; i++) { - if (num % i == 0) { - return false; - } - } - return true; -} - -int main() { - int num; - std::cout << "Enter a number: "; - std::cin >> num; - if (isPrime(num)) { - std::cout << num << " is a prime number." << std::endl; - } else { - std::cout << num << " is not a prime number." << std::endl; - } - return 0; -} -``` - -8. Implement a queue using an array. - -```cpp -#include <iostream> - -class Queue { -private: - int* arr; - int front; - int rear; - int capacity; - int size; - -public: - Queue(int cap) { - capacity = cap; - arr = new int[capacity]; - front = 0; - rear = -1; - size = 0; - } - - void enqueue(int value) { - if (size == capacity) { - std::cout << "Queue is full" << std::endl; - } else { - rear = (rear + 1) % capacity; - arr[rear] = value; - size++; - } - } - - void dequeue() { - if (size == 0) { - std::cout << "Queue is empty" << std::endl; - } else { - front = (front + 1) % capacity; - size--; - } - } - - int peek() { - if (size == 0) { - std::cout << "Queue is empty" << std::endl; - return -1; - } else { - return arr[front]; - } - } - - bool isEmpty() { - return size == 0; - } -}; - -int main() { - Queue queue(3); - queue.enqueue(10); - queue.enqueue(20); - queue.enqueue(30); - std::cout << "Queue: "; - while (!queue.isEmpty()) { - std::cout << queue.peek() << " -> "; - queue.dequeue(); - } - std::cout << "NULL" << std::endl; - return 0; -} -``` - -9. Create a class to represent a student with methods to calculate average marks. - -```cpp -#include <iostream> -#include <vector> - -class Student { -private: - std::vector<int> marks; - -public: - void addMark(int mark) { - marks.push_back(mark); - } - - double calculateAverage() { - if (marks.empty()) { - return 0; - } - int sum = 0; - for (int mark : marks) { - sum += mark; - } - return static_cast<double>(sum) / marks.size(); - } -}; - -int main() { - Student student; - student.addMark(80); - student.addMark(90); - student.addMark(70); - student.addMark(85); - double average = student.calculateAverage(); - std::cout << "Average marks: " << average << std::endl; - return 0; -} -``` - -10. Write a program to find the largest element in an array. - -```cpp -#include <iostream> -#include <vector> - -int findLargestElement(const std::vector<int>& arr) { - int largest = arr[0]; - for (int i = 1; i < arr.size(); i++) { - if (arr[i] > largest) { - largest = arr[i]; - } - } - return largest; -} - -int main() { - std::vector<int> arr = {5, 10, 3, 8, 2}; - int largest = findLargestElement(arr); - std::cout << "The largest element is " << largest << std::endl; - return 0; -} -``` - -11. Implement a binary tree data structure. - -```cpp -#include <iostream> - -class Node { -public: - int data; - Node* left; - Node* right; - - Node(int value) { - data = value; - left = nullptr; - right = nullptr; - } -}; - -class BinaryTree { -private: - Node* root; - -public: - BinaryTree() { - root = nullptr; - } - - void insert(int value) { - Node* newNode = new Node(value); - if (root == nullptr) { - root = newNode; - } else { - Node* current = root; - while (true) { - if (value < current->data) { - if (current->left == nullptr) { - current->left = newNode; - break; - } else { - current = current->left; - } - } else { - if (current->right == nullptr) { - current->right = newNode; - break; - } else { - current = current->right; - } - } - } - } - } - - void printTree(Node* node) { - if (node != nullptr) { - printTree(node->left); - std::cout << node->data << " "; - printTree(node->right); - } - } - - void printTreeInOrder() { - printTree(root); - } -}; - -int main() { - BinaryTree tree; - tree.insert(10); - tree.insert(5); - tree.insert(15); - tree.insert(3); - tree.insert(7); - tree.insert(12); - tree.insert(20); - std::cout << "Tree: "; - tree.printTreeInOrder(); - std::cout << std::endl; - return 0; -} -``` - -12. Create a class to represent a car with methods to start and stop the engine. - -```cpp -#include <iostream> - -class Car { -public: - void startEngine() { - std::cout << "Car engine started." << std::endl; - } - - void stopEngine() { - std::cout << "Car engine stopped." << std::endl; - } -}; - -int main() { - Car car; - car.startEngine(); - car.stopEngine(); - return 0; -} -``` - -13. Write a program to check if a string is a palindrome. - -```cpp -#include <iostream> -#include <string> - -bool isPalindrome(const std::string& str) { - int left = 0; - int right = str.length() - 1; - while (left < right) { - if (str[left] != str[right]) { - return false; - } - left++; - right--; - } - return true; -} - -int main() { - std::string str = "racecar"; - if (isPalindrome(str)) { - std::cout << "\"" << str << "\" is a palindrome." << std::endl; - } else { - std::cout << "\"" << str << "\" is not a palindrome." << std::endl; - } - return 0; -} -``` - -14. Implement a hash table data structure. - -```cpp -#include <iostream> -#include <vector> -#include <list> -#include <utility> - -class HashTable { -private: - std::vector<std::list<std::pair<std::string, int>>> table; - int capacity; - -public: - HashTable(int cap) { - capacity = cap; - table.resize(capacity); - } - - int hashFunction(const std::string& key) { - int sum = 0; - for (char c : key) { - sum += c; - } - return sum % capacity; - } - - void insert(const std::string& key, int value) { - int index = hashFunction(key); - table[index].push_back(std::make_pair(key, value)); - } - - void printTable() { - for (int i = 0; i < capacity; i++) { - std::cout << "Index " << i << ": "; - for (const auto& pair : table[i]) { - std::cout << "(" << pair.first << ", " << pair.second << ") "; - } - std::cout << std::endl; - } - } -}; - -int main() { - HashTable hashTable(3); - hashTable.insert("John", 25); - hashTable.insert("Alice", 30); - hashTable.insert("Bob", 35); - std::cout << "Hash table:" << std::endl; - hashTable.printTable(); - return 0; -} -``` - -15. Create a class to represent a circle with methods to calculate area and circumference. - -```cpp -#include <iostream> -#include <cmath> - -class Circle { -private: - double radius; - -public: - Circle(double r) { - radius = r; - } - - double calculateArea() { - return M_PI * radius * radius; - } - - double calculateCircumference() { - return 2 * M_PI * radius; - } -}; - -int main() { - double radius = 5; - Circle circle(radius); - double area = circle.calculateArea(); - double circumference = circle.calculateCircumference(); - std::cout << "Area: " << area << ", Circumference: " << circumference << std::endl; - return 0; -} -``` - -16. Write a program to sort an array using bubble sort. - -```cpp -#include <iostream> -#include <vector> - -void bubbleSort(std::vector<int>& arr) { - int n = arr.size(); - for (int i = 0; i < n - 1; i++) { - for (int j = 0; j < n - i - 1; j++) { - if (arr[j] > arr[j + 1]) { - std::swap(arr[j], arr[j + 1]); - } - } - } -} - -int main() { - std::vector<int> arr = {5, 2, 8, 1, 9}; - bubbleSort(arr); - std::cout << "Sorted array: "; - for (int num : arr) { - std::cout << num << " "; - } - std::cout << std::endl; - return 0; -} -``` - -17. Implement a linked list data structure. - -```cpp -#include <iostream> - -class Node { -public: - int data; - Node* next; - - Node(int value) { - data = value; - next = nullptr; - } -}; - -class LinkedList { -private: - Node* head; - -public: - LinkedList() { - head = nullptr; - } - - void insert(int value) { - Node* newNode = new Node(value); - if (head == nullptr) { - head = newNode; - } else { - Node* current = head; - while (current->next != nullptr) { - current = current->next; - } - current->next = newNode; - } - } - - void printList() { - Node* current = head; - while (current != nullptr) { - std::cout << current->data << " -> "; - current = current->next; - } - std::cout << "NULL" << std::endl; - } -}; - -int main() { - LinkedList linkedList; - linkedList.insert(10); - linkedList.insert(20); - linkedList.insert(30); - std::cout << "Linked list: "; - linkedList.printList(); - return 0; -} -``` - -18. Create a class to represent a book with methods to get and set the author and title. - -```cpp -#include <iostream> -#include <string> - -class Book { -private: - std::string author; - std::string title; - -public: - void setAuthor(const std::string& a) { - author = a; - } - - void setTitle(const std::string& t) { - title = t; - } - - std::string getAuthor() { - return author; - } - - std::string getTitle() { - return title; - } -}; - -int main() { - Book book; - book.setAuthor("John Doe"); - book.setTitle("The Book"); - std::cout << "Book details: Author: \"" << book.getAuthor() << "\", Title: \"" << book.getTitle() << "\"" << std::endl; - return 0; -} -``` - -19. Write a program to find the sum of all elements in an array. - -```cpp -#include <iostream> -#include <vector> - -int findSum(const std::vector<int>& arr) { - int sum = 0; - for (int num : arr) { - sum += num; - } - return sum; -} - -int main() { - std::vector<int> arr = {1, 2, 3, 4, 5}; - int sum = findSum(arr); - std::cout << "The sum of all elements is " << sum << std::endl; - return 0; -} -``` - -20. Implement a merge sort algorithm. - -```cpp -#include <iostream> -#include <vector> - -void merge(std::vector<int>& arr, int left, int mid, int right) { - int n1 = mid - left + 1; - int n2 = right - mid; - std::vector<int> leftArr(n1); - std::vector<int> rightArr(n2); - for (int i = 0; i < n1; i++) { - leftArr[i] = arr[left + i]; - } - for (int j = 0; j < n2; j++) { - rightArr[j] = arr[mid + 1 + j]; - } - int i = 0; - int j = 0; - int k = left; - while (i < n1 && j < n2) { - if (leftArr[i] <= rightArr[j]) { - arr[k] = leftArr[i]; - i++; - } else { diff --git a/docusaurus.config.js b/docusaurus.config.js index da549228f..cee13dd1b 100644 --- a/docusaurus.config.js +++ b/docusaurus.config.js @@ -1,15 +1,6 @@ -stylesheets: [ - { - href: "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css", - type: "text/css", - }, -], - -import { themes as prismThemes } from "prism-react-renderer"; -require("dotenv").config(); +import {themes as prismThemes} from 'prism-react-renderer'; /** @type {import('@docusaurus/types').Config} */ - const config = { title: "30 Days of CPP", tagline: @@ -32,7 +23,7 @@ const config = { presets: [ [ - "classic", + 'classic', /** @type {import('@docusaurus/preset-classic').Options} */ ({ docs: { @@ -47,131 +38,88 @@ const config = { "https://github.com/subhadipbhowmik/30-Days-Of-CPP/tree/main/", }, theme: { - customCss: require.resolve("./src/css/custom.css"), - }, - pages: { - path: "./src/pages", + customCss: require.resolve('./src/css/custom.css'), }, }), ], ], - stylesheets: [ - { - href: "https://cdnjs.cloudflare.com/ajax/libs/font-awesome/5.15.4/css/all.min.css", - type: "text/css", - }, - ], - themeConfig: /** @type {import('@docusaurus/preset-classic').ThemeConfig} */ ({ + // Replace with your project's social card algolia: { appId: "SKRAQTXG41", apiKey: "4eadbd9906c2db99f8c4d53bb7202144", indexName: "subhadipbhowmik", contextualSearch: false, }, - image: "img/30-days-cpp-banner.png", + image: 'img/docusaurus-social-card.jpg', navbar: { - title: "30 Days of CPP", + title: '30 Days of CPP', logo: { - alt: "30 Days of CPP Programming Logo", - src: "img/logo.svg", + alt: 'My Site Logo', + src: 'img/logo.svg', }, items: [ { - type: "docSidebar", - sidebarId: "tutorialSidebar", - position: "left", - label: "Tutorial", + type: 'docSidebar', + sidebarId: 'tutorialSidebar', + position: 'left', + label: 'Tutorial', }, - { to: "/blog", label: "Blog", position: "left" }, + {to: '/blog', label: 'Blog', position: 'left'}, { - to: "/login", - label: "Login", - position: "right", - }, - { - to: "/signup", - label: "Sign Up", - position: "right", - }, - { - href: "https://github.com/subhadipbhowmik/30-Days-Of-CPP/", - label: "GitHub", - position: "right", - className: "header-github-link", - 'aria-label': "GitHub repository", + href: 'https://github.com/subhadipbhowmik/30-Days-Of-CPP', + label: 'GitHub', + position: 'right', }, ], }, footer: { - style: "dark", + style: 'dark', links: [ { - title: "Learn", + title: 'Learn', items: [ { - label: "Tutorial", - to: "/docs/intro", + label: 'Tutorial', + to: '/docs/intro', + }, + { + label: 'Blog', + to: '/blog', }, ], }, { - title: "Connect with us", + title: 'Community', items: [ { - label: "Facebook", - href: "https://www.facebook.com/", - className: "footer-facebook-link", - }, - { - label: "X", - href: "https://x.com/", - className: "footer-x-link", - }, - { - label: "Discord", - href: "https://discord.com/", - className: "footer-discord-link", - }, - { - label: "LinkedIn", - href: "https://www.linkedin.com/", - className: "footer-linkedin-link", - }, - { - label: "GitHub", - href: "https://github.com/", - className: "footer-github-link", + label: 'Contributors', + href: 'https://github.com/subhadipbhowmik/30-Days-Of-CPP/graphs/contributors', }, ], }, { - title: "More", + title: 'More', items: [ { - label: "Blog", - to: "/blog", + label: 'Fork 🍴', + to: 'https://github.com/subhadipbhowmik/30-Days-Of-CPP/fork', }, { - label: "GitHub", - href: "https://github.com/subhadipbhowmik/30-Days-Of-CPP/", + label: 'GitHub', + href: 'https://github.com/subhadipbhowmik/30-Days-Of-CPP', }, - { - label: "Contact", - to: "/#contact", - } ], }, ], - copyright: `Built with Open Source 🥑 | 30-Days-Of-CPP `, + copyright: `Copyright © ${new Date().getFullYear()} Built with Open Source 🥑.`, }, prism: { theme: prismThemes.github, darkTheme: prismThemes.dracula, - additionalLanguages: ["cpp"], }, }), }; diff --git a/package-lock.json b/package-lock.json index 786363e86..e1daeeb00 100644 --- a/package-lock.json +++ b/package-lock.json @@ -1,32 +1,25 @@ { - "name": "30-days-cpp", - "version": "1.0.0", + "name": "new", + "version": "0.0.0", "lockfileVersion": 3, "requires": true, "packages": { "": { - "name": "30-days-cpp", - "version": "1.0.0", - "license": "MIT", - "dependencies": { - "@docusaurus/core": "^3.3.2", - "@docusaurus/preset-classic": "^3.3.2", - "@docusaurus/theme-search-algolia": "^3.3.2", - "@fortawesome/fontawesome-free": "^6.5.2", - "@fortawesome/fontawesome-svg-core": "^6.5.2", - "@fortawesome/free-brands-svg-icons": "^6.5.2", - "@fortawesome/react-fontawesome": "^0.2.2", + "name": "new", + "version": "0.0.0", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/preset-classic": "3.4.0", + "@docusaurus/theme-search-algolia": "^3.4.0", "@mdx-js/react": "^3.0.0", "clsx": "^2.0.0", - "dotenv": "^16.4.5", "prism-react-renderer": "^2.3.0", "react": "^18.0.0", - "react-dom": "^18.0.0", - "react-helmet": "^6.1.0" + "react-dom": "^18.0.0" }, "devDependencies": { - "@docusaurus/module-type-aliases": "^3.3.2", - "@docusaurus/types": "3.0.1" + "@docusaurus/module-type-aliases": "3.4.0", + "@docusaurus/types": "3.4.0" }, "engines": { "node": ">=18.0" @@ -224,11 +217,11 @@ } }, "node_modules/@babel/code-frame": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.6.tgz", - "integrity": "sha512-ZJhac6FkEd1yhG2AHOmfcXG4ceoLltoCVJjN5XsWN9BifBQr+cHJbWi0h68HZuSORq+3WtJ2z0hwF2NG1b5kcA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/code-frame/-/code-frame-7.24.7.tgz", + "integrity": "sha512-BcYH1CVJBO9tvyIZ2jVeXgSIMvGZ2FDRvDdOIVQyuklNKSsx+eppDEBq/g47Ayw+RqNFE+URvOShmf+f/qwAlA==", "dependencies": { - "@babel/highlight": "^7.24.6", + "@babel/highlight": "^7.24.7", "picocolors": "^1.0.0" }, "engines": { @@ -236,28 +229,28 @@ } }, "node_modules/@babel/compat-data": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.6.tgz", - "integrity": "sha512-aC2DGhBq5eEdyXWqrDInSqQjO0k8xtPRf5YylULqx8MCd6jBtzqfta/3ETMRpuKIc5hyswfO80ObyA1MvkCcUQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/compat-data/-/compat-data-7.24.7.tgz", + "integrity": "sha512-qJzAIcv03PyaWqxRgO4mSU3lihncDT296vnyuE2O8uA4w3UHWI4S3hgeZd1L8W1Bft40w9JxJ2b412iDUFFRhw==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/core": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.6.tgz", - "integrity": "sha512-qAHSfAdVyFmIvl0VHELib8xar7ONuSHrE2hLnsaWkYNTI68dmi1x8GYDhJjMI/e7XWal9QBlZkwbOnkcw7Z8gQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/core/-/core-7.24.7.tgz", + "integrity": "sha512-nykK+LEK86ahTkX/3TgauT0ikKoNCfKHEaZYTUVupJdTLzGNvrblu4u6fa7DhZONAltdf8e662t/abY8idrd/g==", "dependencies": { "@ampproject/remapping": "^2.2.0", - "@babel/code-frame": "^7.24.6", - "@babel/generator": "^7.24.6", - "@babel/helper-compilation-targets": "^7.24.6", - "@babel/helper-module-transforms": "^7.24.6", - "@babel/helpers": "^7.24.6", - "@babel/parser": "^7.24.6", - "@babel/template": "^7.24.6", - "@babel/traverse": "^7.24.6", - "@babel/types": "^7.24.6", + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.24.7", + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helpers": "^7.24.7", + "@babel/parser": "^7.24.7", + "@babel/template": "^7.24.7", + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7", "convert-source-map": "^2.0.0", "debug": "^4.1.0", "gensync": "^1.0.0-beta.2", @@ -281,11 +274,11 @@ } }, "node_modules/@babel/generator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.6.tgz", - "integrity": "sha512-S7m4eNa6YAPJRHmKsLHIDJhNAGNKoWNiWefz1MBbpnt8g9lvMDl1hir4P9bo/57bQEmuwEhnRU/AMWsD0G/Fbg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/generator/-/generator-7.24.7.tgz", + "integrity": "sha512-oipXieGC3i45Y1A41t4tAqpnEZWgB/lC6Ehh6+rOviR5XWpTtMmLN+fGjz9vOiNRt0p6RtO6DtD0pdU3vpqdSA==", "dependencies": { - "@babel/types": "^7.24.6", + "@babel/types": "^7.24.7", "@jridgewell/gen-mapping": "^0.3.5", "@jridgewell/trace-mapping": "^0.3.25", "jsesc": "^2.5.1" @@ -295,34 +288,35 @@ } }, "node_modules/@babel/helper-annotate-as-pure": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.24.6.tgz", - "integrity": "sha512-DitEzDfOMnd13kZnDqns1ccmftwJTS9DMkyn9pYTxulS7bZxUxpMly3Nf23QQ6NwA4UB8lAqjbqWtyvElEMAkg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-annotate-as-pure/-/helper-annotate-as-pure-7.24.7.tgz", + "integrity": "sha512-BaDeOonYvhdKw+JoMVkAixAAJzG2jVPIwWoKBPdYuY9b452e2rPuI9QPYh3KpofZ3pW2akOmwZLOiOsHMiqRAg==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-builder-binary-assignment-operator-visitor": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.24.6.tgz", - "integrity": "sha512-+wnfqc5uHiMYtvRX7qu80Toef8BXeh4HHR1SPeonGb1SKPniNEd4a/nlaJJMv/OIEYvIVavvo0yR7u10Gqz0Iw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-builder-binary-assignment-operator-visitor/-/helper-builder-binary-assignment-operator-visitor-7.24.7.tgz", + "integrity": "sha512-xZeCVVdwb4MsDBkkyZ64tReWYrLRHlMN72vP7Bdm3OUOuyFZExhsHUUnuWnm2/XOlAJzR0LfPpB56WXZn0X/lA==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-compilation-targets": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.24.6.tgz", - "integrity": "sha512-VZQ57UsDGlX/5fFA7GkVPplZhHsVc+vuErWgdOiysI9Ksnw0Pbbd6pnPiR/mmJyKHgyIW0c7KT32gmhiF+cirg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-compilation-targets/-/helper-compilation-targets-7.24.7.tgz", + "integrity": "sha512-ctSdRHBi20qWOfy27RUb4Fhp07KSJ3sXcuSvTrXrc4aG8NSYDo1ici3Vhg9bg69y5bj0Mr1lh0aeEgTvc12rMg==", "dependencies": { - "@babel/compat-data": "^7.24.6", - "@babel/helper-validator-option": "^7.24.6", + "@babel/compat-data": "^7.24.7", + "@babel/helper-validator-option": "^7.24.7", "browserslist": "^4.22.2", "lru-cache": "^5.1.1", "semver": "^6.3.1" @@ -340,18 +334,18 @@ } }, "node_modules/@babel/helper-create-class-features-plugin": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.6.tgz", - "integrity": "sha512-djsosdPJVZE6Vsw3kk7IPRWethP94WHGOhQTc67SNXE0ZzMhHgALw8iGmYS0TD1bbMM0VDROy43od7/hN6WYcA==", - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-function-name": "^7.24.6", - "@babel/helper-member-expression-to-functions": "^7.24.6", - "@babel/helper-optimise-call-expression": "^7.24.6", - "@babel/helper-replace-supers": "^7.24.6", - "@babel/helper-skip-transparent-expression-wrappers": "^7.24.6", - "@babel/helper-split-export-declaration": "^7.24.6", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-create-class-features-plugin/-/helper-create-class-features-plugin-7.24.7.tgz", + "integrity": "sha512-kTkaDl7c9vO80zeX1rJxnuRpEsD5tA81yh11X1gQo+PhSti3JS+7qeZo9U4RHobKRiFPKaGK3svUAeb8D0Q7eg==", + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-member-expression-to-functions": "^7.24.7", + "@babel/helper-optimise-call-expression": "^7.24.7", + "@babel/helper-replace-supers": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", "semver": "^6.3.1" }, "engines": { @@ -370,11 +364,11 @@ } }, "node_modules/@babel/helper-create-regexp-features-plugin": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.24.6.tgz", - "integrity": "sha512-C875lFBIWWwyv6MHZUG9HmRrlTDgOsLWZfYR0nW69gaKJNe0/Mpxx5r0EID2ZdHQkdUmQo2t0uNckTL08/1BgA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-create-regexp-features-plugin/-/helper-create-regexp-features-plugin-7.24.7.tgz", + "integrity": "sha512-03TCmXy2FtXJEZfbXDTSqq1fRJArk7lX9DOFC/47VthYcxyIOx+eXQmdo6DOQvrbpIix+KfXwvuXdFDZHxt+rA==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", + "@babel/helper-annotate-as-pure": "^7.24.7", "regexpu-core": "^5.3.1", "semver": "^6.3.1" }, @@ -409,68 +403,73 @@ } }, "node_modules/@babel/helper-environment-visitor": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.24.6.tgz", - "integrity": "sha512-Y50Cg3k0LKLMjxdPjIl40SdJgMB85iXn27Vk/qbHZCFx/o5XO3PSnpi675h1KEmmDb6OFArfd5SCQEQ5Q4H88g==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-environment-visitor/-/helper-environment-visitor-7.24.7.tgz", + "integrity": "sha512-DoiN84+4Gnd0ncbBOM9AZENV4a5ZiL39HYMyZJGZ/AZEykHYdJw0wW3kdcsh9/Kn+BRXHLkkklZ51ecPKmI1CQ==", + "dependencies": { + "@babel/types": "^7.24.7" + }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-function-name": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.24.6.tgz", - "integrity": "sha512-xpeLqeeRkbxhnYimfr2PC+iA0Q7ljX/d1eZ9/inYbmfG2jpl8Lu3DyXvpOAnrS5kxkfOWJjioIMQsaMBXFI05w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-function-name/-/helper-function-name-7.24.7.tgz", + "integrity": "sha512-FyoJTsj/PEUWu1/TYRiXTIHc8lbw+TDYkZuoE43opPS5TrI7MyONBE1oNvfguEXAD9yhQRrVBnXdXzSLQl9XnA==", "dependencies": { - "@babel/template": "^7.24.6", - "@babel/types": "^7.24.6" + "@babel/template": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-hoist-variables": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.24.6.tgz", - "integrity": "sha512-SF/EMrC3OD7dSta1bLJIlrsVxwtd0UpjRJqLno6125epQMJ/kyFmpTT4pbvPbdQHzCHg+biQ7Syo8lnDtbR+uA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-hoist-variables/-/helper-hoist-variables-7.24.7.tgz", + "integrity": "sha512-MJJwhkoGy5c4ehfoRyrJ/owKeMl19U54h27YYftT0o2teQ3FJ3nQUf/I3LlJsX4l3qlw7WRXUmiyajvHXoTubQ==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-member-expression-to-functions": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.24.6.tgz", - "integrity": "sha512-OTsCufZTxDUsv2/eDXanw/mUZHWOxSbEmC3pP8cgjcy5rgeVPWWMStnv274DV60JtHxTk0adT0QrCzC4M9NWGg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-member-expression-to-functions/-/helper-member-expression-to-functions-7.24.7.tgz", + "integrity": "sha512-LGeMaf5JN4hAT471eJdBs/GK1DoYIJ5GCtZN/EsL6KUiiDZOvO/eKE11AMZJa2zP4zk4qe9V2O/hxAmkRc8p6w==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-module-imports": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.6.tgz", - "integrity": "sha512-a26dmxFJBF62rRO9mmpgrfTLsAuyHk4e1hKTUkD/fcMfynt8gvEKwQPQDVxWhca8dHoDck+55DFt42zV0QMw5g==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-imports/-/helper-module-imports-7.24.7.tgz", + "integrity": "sha512-8AyH3C+74cgCVVXow/myrynrAGv+nTVg5vKu2nZph9x7RcRwzmh0VFallJuFTZ9mx6u4eSdXZfcOzSqTUm0HCA==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-module-transforms": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.24.6.tgz", - "integrity": "sha512-Y/YMPm83mV2HJTbX1Qh2sjgjqcacvOlhbzdCCsSlblOKjSYmQqEbO6rUniWQyRo9ncyfjT8hnUjlG06RXDEmcA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-module-transforms/-/helper-module-transforms-7.24.7.tgz", + "integrity": "sha512-1fuJEwIrp+97rM4RWdO+qrRsZlAeL1lQJoPqtCYWv0NL115XM93hIH4CSRln2w52SqvmY5hqdtauB6QFCDiZNQ==", "dependencies": { - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-module-imports": "^7.24.6", - "@babel/helper-simple-access": "^7.24.6", - "@babel/helper-split-export-declaration": "^7.24.6", - "@babel/helper-validator-identifier": "^7.24.6" + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-simple-access": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -480,32 +479,32 @@ } }, "node_modules/@babel/helper-optimise-call-expression": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.24.6.tgz", - "integrity": "sha512-3SFDJRbx7KuPRl8XDUr8O7GAEB8iGyWPjLKJh/ywP/Iy9WOmEfMrsWbaZpvBu2HSYn4KQygIsz0O7m8y10ncMA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-optimise-call-expression/-/helper-optimise-call-expression-7.24.7.tgz", + "integrity": "sha512-jKiTsW2xmWwxT1ixIdfXUZp+P5yURx2suzLZr5Hi64rURpDYdMW0pv+Uf17EYk2Rd428Lx4tLsnjGJzYKDM/6A==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-plugin-utils": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.6.tgz", - "integrity": "sha512-MZG/JcWfxybKwsA9N9PmtF2lOSFSEMVCpIRrbxccZFLJPrJciJdG/UhSh5W96GEteJI2ARqm5UAHxISwRDLSNg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-plugin-utils/-/helper-plugin-utils-7.24.7.tgz", + "integrity": "sha512-Rq76wjt7yz9AAc1KnlRKNAi/dMSVWgDRx43FHoJEbcYU6xOWaE2dVPwcdTukJrjxS65GITyfbvEYHvkirZ6uEg==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-remap-async-to-generator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.24.6.tgz", - "integrity": "sha512-1Qursq9ArRZPAMOZf/nuzVW8HgJLkTB9y9LfP4lW2MVp4e9WkLJDovfKBxoDcCk6VuzIxyqWHyBoaCtSRP10yg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-remap-async-to-generator/-/helper-remap-async-to-generator-7.24.7.tgz", + "integrity": "sha512-9pKLcTlZ92hNZMQfGCHImUpDOlAgkkpqalWEeftW5FBya75k8Li2ilerxkM/uBEj01iBZXcCIB/bwvDYgWyibA==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-wrap-function": "^7.24.6" + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-wrap-function": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -515,13 +514,13 @@ } }, "node_modules/@babel/helper-replace-supers": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.24.6.tgz", - "integrity": "sha512-mRhfPwDqDpba8o1F8ESxsEkJMQkUF8ZIWrAc0FtWhxnjfextxMWxr22RtFizxxSYLjVHDeMgVsRq8BBZR2ikJQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-replace-supers/-/helper-replace-supers-7.24.7.tgz", + "integrity": "sha512-qTAxxBM81VEyoAY0TtLrx1oAEJc09ZK67Q9ljQToqCnA+55eNwCORaxlKyu+rNfX86o8OXRUSNUnrtsAZXM9sg==", "dependencies": { - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-member-expression-to-functions": "^7.24.6", - "@babel/helper-optimise-call-expression": "^7.24.6" + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-member-expression-to-functions": "^7.24.7", + "@babel/helper-optimise-call-expression": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -531,93 +530,96 @@ } }, "node_modules/@babel/helper-simple-access": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.6.tgz", - "integrity": "sha512-nZzcMMD4ZhmB35MOOzQuiGO5RzL6tJbsT37Zx8M5L/i9KSrukGXWTjLe1knIbb/RmxoJE9GON9soq0c0VEMM5g==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-simple-access/-/helper-simple-access-7.24.7.tgz", + "integrity": "sha512-zBAIvbCMh5Ts+b86r/CjU+4XGYIs+R1j951gxI3KmmxBMhCg4oQMsv6ZXQ64XOm/cvzfU1FmoCyt6+owc5QMYg==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-skip-transparent-expression-wrappers": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.24.6.tgz", - "integrity": "sha512-jhbbkK3IUKc4T43WadP96a27oYti9gEf1LdyGSP2rHGH77kwLwfhO7TgwnWvxxQVmke0ImmCSS47vcuxEMGD3Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-skip-transparent-expression-wrappers/-/helper-skip-transparent-expression-wrappers-7.24.7.tgz", + "integrity": "sha512-IO+DLT3LQUElMbpzlatRASEyQtfhSE0+m465v++3jyyXeBTBUjtVZg28/gHeV5mrTJqvEKhKroBGAvhW+qPHiQ==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-split-export-declaration": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.24.6.tgz", - "integrity": "sha512-CvLSkwXGWnYlF9+J3iZUvwgAxKiYzK3BWuo+mLzD/MDGOZDj7Gq8+hqaOkMxmJwmlv0iu86uH5fdADd9Hxkymw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-split-export-declaration/-/helper-split-export-declaration-7.24.7.tgz", + "integrity": "sha512-oy5V7pD+UvfkEATUKvIjvIAH/xCzfsFVw7ygW2SI6NClZzquT+mwdTfgfdbUiceh6iQO0CHtCPsyze/MZ2YbAA==", "dependencies": { - "@babel/types": "^7.24.6" + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-string-parser": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.6.tgz", - "integrity": "sha512-WdJjwMEkmBicq5T9fm/cHND3+UlFa2Yj8ALLgmoSQAJZysYbBjw+azChSGPN4DSPLXOcooGRvDwZWMcF/mLO2Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-string-parser/-/helper-string-parser-7.24.7.tgz", + "integrity": "sha512-7MbVt6xrwFQbunH2DNQsAP5sTGxfqQtErvBIvIMi6EQnbgUOuVYanvREcmFrOPhoXBrTtjhhP+lW+o5UfK+tDg==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-validator-identifier": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.6.tgz", - "integrity": "sha512-4yA7s865JHaqUdRbnaxarZREuPTHrjpDT+pXoAZ1yhyo6uFnIEpS8VMu16siFOHDpZNKYv5BObhsB//ycbICyw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-identifier/-/helper-validator-identifier-7.24.7.tgz", + "integrity": "sha512-rR+PBcQ1SMQDDyF6X0wxtG8QyLCgUB0eRAGguqRLfkCA87l7yAP7ehq8SNj96OOGTO8OBV70KhuFYcIkHXOg0w==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-validator-option": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.6.tgz", - "integrity": "sha512-Jktc8KkF3zIkePb48QO+IapbXlSapOW9S+ogZZkcO6bABgYAxtZcjZ/O005111YLf+j4M84uEgwYoidDkXbCkQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-validator-option/-/helper-validator-option-7.24.7.tgz", + "integrity": "sha512-yy1/KvjhV/ZCL+SM7hBrvnZJ3ZuT9OuZgIJAGpPEToANvc3iM6iDvBnRjtElWibHU6n8/LPR/EjX9EtIEYO3pw==", "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helper-wrap-function": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.24.6.tgz", - "integrity": "sha512-f1JLrlw/jbiNfxvdrfBgio/gRBk3yTAEJWirpAkiJG2Hb22E7cEYKHWo0dFPTv/niPovzIdPdEDetrv6tC6gPQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helper-wrap-function/-/helper-wrap-function-7.24.7.tgz", + "integrity": "sha512-N9JIYk3TD+1vq/wn77YnJOqMtfWhNewNE+DJV4puD2X7Ew9J4JvrzrFDfTfyv5EgEXVy9/Wt8QiOErzEmv5Ifw==", "dependencies": { - "@babel/helper-function-name": "^7.24.6", - "@babel/template": "^7.24.6", - "@babel/types": "^7.24.6" + "@babel/helper-function-name": "^7.24.7", + "@babel/template": "^7.24.7", + "@babel/traverse": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/helpers": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.6.tgz", - "integrity": "sha512-V2PI+NqnyFu1i0GyTd/O/cTpxzQCYioSkUIRmgo7gFEHKKCg5w46+r/A6WeUR1+P3TeQ49dspGPNd/E3n9AnnA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/helpers/-/helpers-7.24.7.tgz", + "integrity": "sha512-NlmJJtvcw72yRJRcnCmGvSi+3jDEg8qFu3z0AFoymmzLx5ERVWyzd9kVXr7Th9/8yIJi2Zc6av4Tqz3wFs8QWg==", "dependencies": { - "@babel/template": "^7.24.6", - "@babel/types": "^7.24.6" + "@babel/template": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/highlight": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.6.tgz", - "integrity": "sha512-2YnuOp4HAk2BsBrJJvYCbItHx0zWscI1C3zgWkz+wDyD9I7GIVrfnLyrR4Y1VR+7p+chAEcrgRQYZAGIKMV7vQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/highlight/-/highlight-7.24.7.tgz", + "integrity": "sha512-EStJpq4OuY8xYfhGVXngigBJRWxftKX9ksiGDnmlY3o7B/V7KIAc9X4oiK87uPJSc/vs5L869bem5fhZa8caZw==", "dependencies": { - "@babel/helper-validator-identifier": "^7.24.6", + "@babel/helper-validator-identifier": "^7.24.7", "chalk": "^2.4.2", "js-tokens": "^4.0.0", "picocolors": "^1.0.0" @@ -691,9 +693,9 @@ } }, "node_modules/@babel/parser": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.6.tgz", - "integrity": "sha512-eNZXdfU35nJC2h24RznROuOpO94h6x8sg9ju0tT9biNtLZ2vuP8SduLqqV+/8+cebSLV9SJEAN5Z3zQbJG/M+Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/parser/-/parser-7.24.7.tgz", + "integrity": "sha512-9uUYRm6OqQrCqQdG1iCBwBPZgN8ciDBro2nIOFaiRz1/BCxaI7CNvQbDHvsArAC7Tw9Hda/B3U+6ui9u4HWXPw==", "bin": { "parser": "bin/babel-parser.js" }, @@ -702,12 +704,12 @@ } }, "node_modules/@babel/plugin-bugfix-firefox-class-in-computed-class-key": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.24.6.tgz", - "integrity": "sha512-bYndrJ6Ph6Ar+GaB5VAc0JPoP80bQCm4qon6JEzXfRl5QZyQ8Ur1K6k7htxWmPA5z+k7JQvaMUrtXlqclWYzKw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-firefox-class-in-computed-class-key/-/plugin-bugfix-firefox-class-in-computed-class-key-7.24.7.tgz", + "integrity": "sha512-TiT1ss81W80eQsN+722OaeQMY/G4yTb4G9JrqeiDADs3N8lbPMGldWi9x8tyqCW5NLx1Jh2AvkE6r6QvEltMMQ==", "dependencies": { - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -717,11 +719,11 @@ } }, "node_modules/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.24.6.tgz", - "integrity": "sha512-iVuhb6poq5ikqRq2XWU6OQ+R5o9wF+r/or9CeUyovgptz0UlnK4/seOQ1Istu/XybYjAhQv1FRSSfHHufIku5Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression/-/plugin-bugfix-safari-id-destructuring-collision-in-function-expression-7.24.7.tgz", + "integrity": "sha512-unaQgZ/iRu/By6tsjMZzpeBZjChYfLYry6HrEXPoz3KmfF0sVBQ1l8zKMQ4xRGLWVsjuvB8nQfjNP/DcfEOCsg==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -731,13 +733,13 @@ } }, "node_modules/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.24.6.tgz", - "integrity": "sha512-c8TER5xMDYzzFcGqOEp9l4hvB7dcbhcGjcLVwxWfe4P5DOafdwjsBJZKsmv+o3aXh7NhopvayQIovHrh2zSRUQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining/-/plugin-bugfix-v8-spread-parameters-in-optional-chaining-7.24.7.tgz", + "integrity": "sha512-+izXIbke1T33mY4MSNnrqhPXDz01WYhEf3yF5NbnUtkiNnm+XBZJl3kNfoK6NKmYlz/D07+l2GWVK/QfDkNCuQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-skip-transparent-expression-wrappers": "^7.24.6", - "@babel/plugin-transform-optional-chaining": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7", + "@babel/plugin-transform-optional-chaining": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -747,12 +749,12 @@ } }, "node_modules/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.24.6.tgz", - "integrity": "sha512-z8zEjYmwBUHN/pCF3NuWBhHQjJCrd33qAi8MgANfMrAvn72k2cImT8VjK9LJFu4ysOLJqhfkYYb3MvwANRUNZQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly/-/plugin-bugfix-v8-static-class-fields-redefine-readonly-7.24.7.tgz", + "integrity": "sha512-utA4HuR6F4Vvcr+o4DnjL8fCOlgRFGbeeBEGNg3ZTrLFw6VWG5XmUrvcQ0FjIYMU2ST4XcR2Wsp7t9qOAPnxMg==", "dependencies": { - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -831,11 +833,11 @@ } }, "node_modules/@babel/plugin-syntax-import-assertions": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.24.6.tgz", - "integrity": "sha512-BE6o2BogJKJImTmGpkmOic4V0hlRRxVtzqxiSPa8TIFxyhi4EFjHm08nq1M4STK4RytuLMgnSz0/wfflvGFNOg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-assertions/-/plugin-syntax-import-assertions-7.24.7.tgz", + "integrity": "sha512-Ec3NRUMoi8gskrkBe3fNmEQfxDvY8bgfQpz6jlk/41kX9eUjvpyqWU7PBP/pLAvMaSQjbMNKJmvX57jP+M6bPg==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -845,11 +847,11 @@ } }, "node_modules/@babel/plugin-syntax-import-attributes": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.24.6.tgz", - "integrity": "sha512-D+CfsVZousPXIdudSII7RGy52+dYRtbyKAZcvtQKq/NpsivyMVduepzcLqG5pMBugtMdedxdC8Ramdpcne9ZWQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-import-attributes/-/plugin-syntax-import-attributes-7.24.7.tgz", + "integrity": "sha512-hbX+lKKeUMGihnK8nvKqmXBInriT3GVjzXKFriV3YC6APGxMbP8RZNFwy91+hocLXq90Mta+HshoB31802bb8A==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -881,11 +883,11 @@ } }, "node_modules/@babel/plugin-syntax-jsx": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.6.tgz", - "integrity": "sha512-lWfvAIFNWMlCsU0DRUun2GpFwZdGTukLaHJqRh1JRb80NdAP5Sb1HDHB5X9P9OtgZHQl089UzQkpYlBq2VTPRw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-jsx/-/plugin-syntax-jsx-7.24.7.tgz", + "integrity": "sha512-6ddciUPe/mpMnOKv/U+RSd2vvVy+Yw/JfBB0ZHYjEZt9NLHmCUylNYlsbqCCS1Bffjlb0fCwC9Vqz+sBz6PsiQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -989,11 +991,11 @@ } }, "node_modules/@babel/plugin-syntax-typescript": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.6.tgz", - "integrity": "sha512-TzCtxGgVTEJWWwcYwQhCIQ6WaKlo80/B+Onsk4RRCcYqpYGFcG9etPW94VToGte5AAcxRrhjPUFvUS3Y2qKi4A==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-syntax-typescript/-/plugin-syntax-typescript-7.24.7.tgz", + "integrity": "sha512-c/+fVeJBB0FeKsFvwytYiUD+LBvhHjGSI0g446PRGdSVGZLRNArBUno2PETbAly3tpiNAQR5XaZ+JslxkotsbA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1018,11 +1020,11 @@ } }, "node_modules/@babel/plugin-transform-arrow-functions": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.24.6.tgz", - "integrity": "sha512-jSSSDt4ZidNMggcLx8SaKsbGNEfIl0PHx/4mFEulorE7bpYLbN0d3pDW3eJ7Y5Z3yPhy3L3NaPCYyTUY7TuugQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-arrow-functions/-/plugin-transform-arrow-functions-7.24.7.tgz", + "integrity": "sha512-Dt9LQs6iEY++gXUwY03DNFat5C2NbO48jj+j/bSAz6b3HgPs39qcPiYt77fDObIcFwj3/C2ICX9YMwGflUoSHQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1032,13 +1034,13 @@ } }, "node_modules/@babel/plugin-transform-async-generator-functions": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.24.6.tgz", - "integrity": "sha512-VEP2o4iR2DqQU6KPgizTW2mnMx6BG5b5O9iQdrW9HesLkv8GIA8x2daXBQxw1MrsIkFQGA/iJ204CKoQ8UcnAA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-generator-functions/-/plugin-transform-async-generator-functions-7.24.7.tgz", + "integrity": "sha512-o+iF77e3u7ZS4AoAuJvapz9Fm001PuD2V3Lp6OSE4FYQke+cSewYtnek+THqGRWyQloRCyvWL1OkyfNEl9vr/g==", "dependencies": { - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-remap-async-to-generator": "^7.24.6", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-remap-async-to-generator": "^7.24.7", "@babel/plugin-syntax-async-generators": "^7.8.4" }, "engines": { @@ -1049,13 +1051,13 @@ } }, "node_modules/@babel/plugin-transform-async-to-generator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.24.6.tgz", - "integrity": "sha512-NTBA2SioI3OsHeIn6sQmhvXleSl9T70YY/hostQLveWs0ic+qvbA3fa0kwAwQ0OA/XGaAerNZRQGJyRfhbJK4g==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-async-to-generator/-/plugin-transform-async-to-generator-7.24.7.tgz", + "integrity": "sha512-SQY01PcJfmQ+4Ash7NE+rpbLFbmqA2GPIgqzxfFTL4t1FKRq4zTms/7htKpoCUI9OcFYgzqfmCdH53s6/jn5fA==", "dependencies": { - "@babel/helper-module-imports": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-remap-async-to-generator": "^7.24.6" + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-remap-async-to-generator": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1065,11 +1067,11 @@ } }, "node_modules/@babel/plugin-transform-block-scoped-functions": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.24.6.tgz", - "integrity": "sha512-XNW7jolYHW9CwORrZgA/97tL/k05qe/HL0z/qqJq1mdWhwwCM6D4BJBV7wAz9HgFziN5dTOG31znkVIzwxv+vw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoped-functions/-/plugin-transform-block-scoped-functions-7.24.7.tgz", + "integrity": "sha512-yO7RAz6EsVQDaBH18IDJcMB1HnrUn2FJ/Jslc/WtPPWcjhpUJXU/rjbwmluzp7v/ZzWcEhTMXELnnsz8djWDwQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1079,11 +1081,11 @@ } }, "node_modules/@babel/plugin-transform-block-scoping": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.24.6.tgz", - "integrity": "sha512-S/t1Xh4ehW7sGA7c1j/hiOBLnEYCp/c2sEG4ZkL8kI1xX9tW2pqJTCHKtdhe/jHKt8nG0pFCrDHUXd4DvjHS9w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-block-scoping/-/plugin-transform-block-scoping-7.24.7.tgz", + "integrity": "sha512-Nd5CvgMbWc+oWzBsuaMcbwjJWAcp5qzrbg69SZdHSP7AMY0AbWFqFO0WTFCA1jxhMCwodRwvRec8k0QUbZk7RQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1093,12 +1095,12 @@ } }, "node_modules/@babel/plugin-transform-class-properties": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.24.6.tgz", - "integrity": "sha512-j6dZ0Z2Z2slWLR3kt9aOmSIrBvnntWjMDN/TVcMPxhXMLmJVqX605CBRlcGI4b32GMbfifTEsdEjGjiE+j/c3A==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-properties/-/plugin-transform-class-properties-7.24.7.tgz", + "integrity": "sha512-vKbfawVYayKcSeSR5YYzzyXvsDFWU2mD8U5TFeXtbCPLFUqe7GyCgvO6XDHzje862ODrOwy6WCPmKeWHbCFJ4w==", "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1108,12 +1110,12 @@ } }, "node_modules/@babel/plugin-transform-class-static-block": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.24.6.tgz", - "integrity": "sha512-1QSRfoPI9RoLRa8Mnakc6v3e0gJxiZQTYrMfLn+mD0sz5+ndSzwymp2hDcYJTyT0MOn0yuWzj8phlIvO72gTHA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-class-static-block/-/plugin-transform-class-static-block-7.24.7.tgz", + "integrity": "sha512-HMXK3WbBPpZQufbMG4B46A90PkuuhN9vBCb5T8+VAHqvAqvcLi+2cKoukcpmUYkszLhScU3l1iudhrks3DggRQ==", "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-class-static-block": "^7.14.5" }, "engines": { @@ -1124,17 +1126,17 @@ } }, "node_modules/@babel/plugin-transform-classes": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.24.6.tgz", - "integrity": "sha512-+fN+NO2gh8JtRmDSOB6gaCVo36ha8kfCW1nMq2Gc0DABln0VcHN4PrALDvF5/diLzIRKptC7z/d7Lp64zk92Fg==", - "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-compilation-targets": "^7.24.6", - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-function-name": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-replace-supers": "^7.24.6", - "@babel/helper-split-export-declaration": "^7.24.6", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-classes/-/plugin-transform-classes-7.24.7.tgz", + "integrity": "sha512-CFbbBigp8ln4FU6Bpy6g7sE8B/WmCmzvivzUC6xDAdWVsjYTXijpuuGJmYkAaoWAzcItGKT3IOAbxRItZ5HTjw==", + "dependencies": { + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-replace-supers": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", "globals": "^11.1.0" }, "engines": { @@ -1145,12 +1147,12 @@ } }, "node_modules/@babel/plugin-transform-computed-properties": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.24.6.tgz", - "integrity": "sha512-cRzPobcfRP0ZtuIEkA8QzghoUpSB3X3qSH5W2+FzG+VjWbJXExtx0nbRqwumdBN1x/ot2SlTNQLfBCnPdzp6kg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-computed-properties/-/plugin-transform-computed-properties-7.24.7.tgz", + "integrity": "sha512-25cS7v+707Gu6Ds2oY6tCkUwsJ9YIDbggd9+cu9jzzDgiNq7hR/8dkzxWfKWnTic26vsI3EsCXNd4iEB6e8esQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/template": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/template": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1160,11 +1162,11 @@ } }, "node_modules/@babel/plugin-transform-destructuring": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.24.6.tgz", - "integrity": "sha512-YLW6AE5LQpk5npNXL7i/O+U9CE4XsBCuRPgyjl1EICZYKmcitV+ayuuUGMJm2lC1WWjXYszeTnIxF/dq/GhIZQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-destructuring/-/plugin-transform-destructuring-7.24.7.tgz", + "integrity": "sha512-19eJO/8kdCQ9zISOf+SEUJM/bAUIsvY3YDnXZTupUCQ8LgrWnsG/gFB9dvXqdXnRXMAM8fvt7b0CBKQHNGy1mw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1174,12 +1176,12 @@ } }, "node_modules/@babel/plugin-transform-dotall-regex": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.24.6.tgz", - "integrity": "sha512-rCXPnSEKvkm/EjzOtLoGvKseK+dS4kZwx1HexO3BtRtgL0fQ34awHn34aeSHuXtZY2F8a1X8xqBBPRtOxDVmcA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dotall-regex/-/plugin-transform-dotall-regex-7.24.7.tgz", + "integrity": "sha512-ZOA3W+1RRTSWvyqcMJDLqbchh7U4NRGqwRfFSVbOLS/ePIP4vHB5e8T8eXcuqyN1QkgKyj5wuW0lcS85v4CrSw==", "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1189,11 +1191,11 @@ } }, "node_modules/@babel/plugin-transform-duplicate-keys": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.24.6.tgz", - "integrity": "sha512-/8Odwp/aVkZwPFJMllSbawhDAO3UJi65foB00HYnK/uXvvCPm0TAXSByjz1mpRmp0q6oX2SIxpkUOpPFHk7FLA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-duplicate-keys/-/plugin-transform-duplicate-keys-7.24.7.tgz", + "integrity": "sha512-JdYfXyCRihAe46jUIliuL2/s0x0wObgwwiGxw/UbgJBr20gQBThrokO4nYKgWkD7uBaqM7+9x5TU7NkExZJyzw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1203,11 +1205,11 @@ } }, "node_modules/@babel/plugin-transform-dynamic-import": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.24.6.tgz", - "integrity": "sha512-vpq8SSLRTBLOHUZHSnBqVo0AKX3PBaoPs2vVzYVWslXDTDIpwAcCDtfhUcHSQQoYoUvcFPTdC8TZYXu9ZnLT/w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-dynamic-import/-/plugin-transform-dynamic-import-7.24.7.tgz", + "integrity": "sha512-sc3X26PhZQDb3JhORmakcbvkeInvxz+A8oda99lj7J60QRuPZvNAk9wQlTBS1ZynelDrDmTU4pw1tyc5d5ZMUg==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-dynamic-import": "^7.8.3" }, "engines": { @@ -1218,12 +1220,12 @@ } }, "node_modules/@babel/plugin-transform-exponentiation-operator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.24.6.tgz", - "integrity": "sha512-EemYpHtmz0lHE7hxxxYEuTYOOBZ43WkDgZ4arQ4r+VX9QHuNZC+WH3wUWmRNvR8ECpTRne29aZV6XO22qpOtdA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-exponentiation-operator/-/plugin-transform-exponentiation-operator-7.24.7.tgz", + "integrity": "sha512-Rqe/vSc9OYgDajNIK35u7ot+KeCoetqQYFXM4Epf7M7ez3lWlOjrDjrwMei6caCVhfdw+mIKD4cgdGNy5JQotQ==", "dependencies": { - "@babel/helper-builder-binary-assignment-operator-visitor": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-builder-binary-assignment-operator-visitor": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1233,11 +1235,11 @@ } }, "node_modules/@babel/plugin-transform-export-namespace-from": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.24.6.tgz", - "integrity": "sha512-inXaTM1SVrIxCkIJ5gqWiozHfFMStuGbGJAxZFBoHcRRdDP0ySLb3jH6JOwmfiinPwyMZqMBX+7NBDCO4z0NSA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-export-namespace-from/-/plugin-transform-export-namespace-from-7.24.7.tgz", + "integrity": "sha512-v0K9uNYsPL3oXZ/7F9NNIbAj2jv1whUEtyA6aujhekLs56R++JDQuzRcP2/z4WX5Vg/c5lE9uWZA0/iUoFhLTA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-export-namespace-from": "^7.8.3" }, "engines": { @@ -1248,12 +1250,12 @@ } }, "node_modules/@babel/plugin-transform-for-of": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.24.6.tgz", - "integrity": "sha512-n3Sf72TnqK4nw/jziSqEl1qaWPbCRw2CziHH+jdRYvw4J6yeCzsj4jdw8hIntOEeDGTmHVe2w4MVL44PN0GMzg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-for-of/-/plugin-transform-for-of-7.24.7.tgz", + "integrity": "sha512-wo9ogrDG1ITTTBsy46oGiN1dS9A7MROBTcYsfS8DtsImMkHk9JXJ3EWQM6X2SUw4x80uGPlwj0o00Uoc6nEE3g==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-skip-transparent-expression-wrappers": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1263,13 +1265,13 @@ } }, "node_modules/@babel/plugin-transform-function-name": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.24.6.tgz", - "integrity": "sha512-sOajCu6V0P1KPljWHKiDq6ymgqB+vfo3isUS4McqW1DZtvSVU2v/wuMhmRmkg3sFoq6GMaUUf8W4WtoSLkOV/Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-function-name/-/plugin-transform-function-name-7.24.7.tgz", + "integrity": "sha512-U9FcnA821YoILngSmYkW6FjyQe2TyZD5pHt4EVIhmcTkrJw/3KqcrRSxuOo5tFZJi7TE19iDyI1u+weTI7bn2w==", "dependencies": { - "@babel/helper-compilation-targets": "^7.24.6", - "@babel/helper-function-name": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1279,11 +1281,11 @@ } }, "node_modules/@babel/plugin-transform-json-strings": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.24.6.tgz", - "integrity": "sha512-Uvgd9p2gUnzYJxVdBLcU0KurF8aVhkmVyMKW4MIY1/BByvs3EBpv45q01o7pRTVmTvtQq5zDlytP3dcUgm7v9w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-json-strings/-/plugin-transform-json-strings-7.24.7.tgz", + "integrity": "sha512-2yFnBGDvRuxAaE/f0vfBKvtnvvqU8tGpMHqMNpTN2oWMKIR3NqFkjaAgGwawhqK/pIN2T3XdjGPdaG0vDhOBGw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-json-strings": "^7.8.3" }, "engines": { @@ -1294,11 +1296,11 @@ } }, "node_modules/@babel/plugin-transform-literals": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.24.6.tgz", - "integrity": "sha512-f2wHfR2HF6yMj+y+/y07+SLqnOSwRp8KYLpQKOzS58XLVlULhXbiYcygfXQxJlMbhII9+yXDwOUFLf60/TL5tw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-literals/-/plugin-transform-literals-7.24.7.tgz", + "integrity": "sha512-vcwCbb4HDH+hWi8Pqenwnjy+UiklO4Kt1vfspcQYFhJdpthSnW8XvWGyDZWKNVrVbVViI/S7K9PDJZiUmP2fYQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1308,11 +1310,11 @@ } }, "node_modules/@babel/plugin-transform-logical-assignment-operators": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.24.6.tgz", - "integrity": "sha512-EKaWvnezBCMkRIHxMJSIIylzhqK09YpiJtDbr2wsXTwnO0TxyjMUkaw4RlFIZMIS0iDj0KyIg7H7XCguHu/YDA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-logical-assignment-operators/-/plugin-transform-logical-assignment-operators-7.24.7.tgz", + "integrity": "sha512-4D2tpwlQ1odXmTEIFWy9ELJcZHqrStlzK/dAOWYyxX3zT0iXQB6banjgeOJQXzEc4S0E0a5A+hahxPaEFYftsw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4" }, "engines": { @@ -1323,11 +1325,11 @@ } }, "node_modules/@babel/plugin-transform-member-expression-literals": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.24.6.tgz", - "integrity": "sha512-9g8iV146szUo5GWgXpRbq/GALTnY+WnNuRTuRHWWFfWGbP9ukRL0aO/jpu9dmOPikclkxnNsjY8/gsWl6bmZJQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-member-expression-literals/-/plugin-transform-member-expression-literals-7.24.7.tgz", + "integrity": "sha512-T/hRC1uqrzXMKLQ6UCwMT85S3EvqaBXDGf0FaMf4446Qx9vKwlghvee0+uuZcDUCZU5RuNi4781UQ7R308zzBw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1337,12 +1339,12 @@ } }, "node_modules/@babel/plugin-transform-modules-amd": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.24.6.tgz", - "integrity": "sha512-eAGogjZgcwqAxhyFgqghvoHRr+EYRQPFjUXrTYKBRb5qPnAVxOOglaxc4/byHqjvq/bqO2F3/CGwTHsgKJYHhQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-amd/-/plugin-transform-modules-amd-7.24.7.tgz", + "integrity": "sha512-9+pB1qxV3vs/8Hdmz/CulFB8w2tuu6EB94JZFsjdqxQokwGa9Unap7Bo2gGBGIvPmDIVvQrom7r5m/TCDMURhg==", "dependencies": { - "@babel/helper-module-transforms": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1352,13 +1354,13 @@ } }, "node_modules/@babel/plugin-transform-modules-commonjs": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.24.6.tgz", - "integrity": "sha512-JEV8l3MHdmmdb7S7Cmx6rbNEjRCgTQMZxllveHO0mx6uiclB0NflCawlQQ6+o5ZrwjUBYPzHm2XoK4wqGVUFuw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-commonjs/-/plugin-transform-modules-commonjs-7.24.7.tgz", + "integrity": "sha512-iFI8GDxtevHJ/Z22J5xQpVqFLlMNstcLXh994xifFwxxGslr2ZXXLWgtBeLctOD63UFDArdvN6Tg8RFw+aEmjQ==", "dependencies": { - "@babel/helper-module-transforms": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-simple-access": "^7.24.6" + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-simple-access": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1368,14 +1370,14 @@ } }, "node_modules/@babel/plugin-transform-modules-systemjs": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.24.6.tgz", - "integrity": "sha512-xg1Z0J5JVYxtpX954XqaaAT6NpAY6LtZXvYFCJmGFJWwtlz2EmJoR8LycFRGNE8dBKizGWkGQZGegtkV8y8s+w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-systemjs/-/plugin-transform-modules-systemjs-7.24.7.tgz", + "integrity": "sha512-GYQE0tW7YoaN13qFh3O1NCY4MPkUiAH3fiF7UcV/I3ajmDKEdG3l+UOcbAm4zUE3gnvUU+Eni7XrVKo9eO9auw==", "dependencies": { - "@babel/helper-hoist-variables": "^7.24.6", - "@babel/helper-module-transforms": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-validator-identifier": "^7.24.6" + "@babel/helper-hoist-variables": "^7.24.7", + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1385,12 +1387,12 @@ } }, "node_modules/@babel/plugin-transform-modules-umd": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.24.6.tgz", - "integrity": "sha512-esRCC/KsSEUvrSjv5rFYnjZI6qv4R1e/iHQrqwbZIoRJqk7xCvEUiN7L1XrmW5QSmQe3n1XD88wbgDTWLbVSyg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-modules-umd/-/plugin-transform-modules-umd-7.24.7.tgz", + "integrity": "sha512-3aytQvqJ/h9z4g8AsKPLvD4Zqi2qT+L3j7XoFFu1XBlZWEl2/1kWnhmAbxpLgPrHSY0M6UA02jyTiwUVtiKR6A==", "dependencies": { - "@babel/helper-module-transforms": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-module-transforms": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1400,12 +1402,12 @@ } }, "node_modules/@babel/plugin-transform-named-capturing-groups-regex": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.24.6.tgz", - "integrity": "sha512-6DneiCiu91wm3YiNIGDWZsl6GfTTbspuj/toTEqLh9d4cx50UIzSdg+T96p8DuT7aJOBRhFyaE9ZvTHkXrXr6Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-named-capturing-groups-regex/-/plugin-transform-named-capturing-groups-regex-7.24.7.tgz", + "integrity": "sha512-/jr7h/EWeJtk1U/uz2jlsCioHkZk1JJZVcc8oQsJ1dUlaJD83f4/6Zeh2aHt9BIFokHIsSeDfhUmju0+1GPd6g==", "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1415,11 +1417,11 @@ } }, "node_modules/@babel/plugin-transform-new-target": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.24.6.tgz", - "integrity": "sha512-f8liz9JG2Va8A4J5ZBuaSdwfPqN6axfWRK+y66fjKYbwf9VBLuq4WxtinhJhvp1w6lamKUwLG0slK2RxqFgvHA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-new-target/-/plugin-transform-new-target-7.24.7.tgz", + "integrity": "sha512-RNKwfRIXg4Ls/8mMTza5oPF5RkOW8Wy/WgMAp1/F1yZ8mMbtwXW+HDoJiOsagWrAhI5f57Vncrmr9XeT4CVapA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1429,11 +1431,11 @@ } }, "node_modules/@babel/plugin-transform-nullish-coalescing-operator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.24.6.tgz", - "integrity": "sha512-+QlAiZBMsBK5NqrBWFXCYeXyiU1y7BQ/OYaiPAcQJMomn5Tyg+r5WuVtyEuvTbpV7L25ZSLfE+2E9ywj4FD48A==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-nullish-coalescing-operator/-/plugin-transform-nullish-coalescing-operator-7.24.7.tgz", + "integrity": "sha512-Ts7xQVk1OEocqzm8rHMXHlxvsfZ0cEF2yomUqpKENHWMF4zKk175Y4q8H5knJes6PgYad50uuRmt3UJuhBw8pQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-nullish-coalescing-operator": "^7.8.3" }, "engines": { @@ -1444,11 +1446,11 @@ } }, "node_modules/@babel/plugin-transform-numeric-separator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.24.6.tgz", - "integrity": "sha512-6voawq8T25Jvvnc4/rXcWZQKKxUNZcKMS8ZNrjxQqoRFernJJKjE3s18Qo6VFaatG5aiX5JV1oPD7DbJhn0a4Q==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-numeric-separator/-/plugin-transform-numeric-separator-7.24.7.tgz", + "integrity": "sha512-e6q1TiVUzvH9KRvicuxdBTUj4AdKSRwzIyFFnfnezpCfP2/7Qmbb8qbU2j7GODbl4JMkblitCQjKYUaX/qkkwA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-numeric-separator": "^7.10.4" }, "engines": { @@ -1459,14 +1461,14 @@ } }, "node_modules/@babel/plugin-transform-object-rest-spread": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.24.6.tgz", - "integrity": "sha512-OKmi5wiMoRW5Smttne7BwHM8s/fb5JFs+bVGNSeHWzwZkWXWValR1M30jyXo1s/RaqgwwhEC62u4rFH/FBcBPg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-rest-spread/-/plugin-transform-object-rest-spread-7.24.7.tgz", + "integrity": "sha512-4QrHAr0aXQCEFni2q4DqKLD31n2DL+RxcwnNjDFkSG0eNQ/xCavnRkfCUjsyqGC2OviNJvZOF/mQqZBw7i2C5Q==", "dependencies": { - "@babel/helper-compilation-targets": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-object-rest-spread": "^7.8.3", - "@babel/plugin-transform-parameters": "^7.24.6" + "@babel/plugin-transform-parameters": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1476,12 +1478,12 @@ } }, "node_modules/@babel/plugin-transform-object-super": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.24.6.tgz", - "integrity": "sha512-N/C76ihFKlZgKfdkEYKtaRUtXZAgK7sOY4h2qrbVbVTXPrKGIi8aww5WGe/+Wmg8onn8sr2ut6FXlsbu/j6JHg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-object-super/-/plugin-transform-object-super-7.24.7.tgz", + "integrity": "sha512-A/vVLwN6lBrMFmMDmPPz0jnE6ZGx7Jq7d6sT/Ev4H65RER6pZ+kczlf1DthF5N0qaPHBsI7UXiE8Zy66nmAovg==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-replace-supers": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-replace-supers": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1491,11 +1493,11 @@ } }, "node_modules/@babel/plugin-transform-optional-catch-binding": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.24.6.tgz", - "integrity": "sha512-L5pZ+b3O1mSzJ71HmxSCmTVd03VOT2GXOigug6vDYJzE5awLI7P1g0wFcdmGuwSDSrQ0L2rDOe/hHws8J1rv3w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-catch-binding/-/plugin-transform-optional-catch-binding-7.24.7.tgz", + "integrity": "sha512-uLEndKqP5BfBbC/5jTwPxLh9kqPWWgzN/f8w6UwAIirAEqiIVJWWY312X72Eub09g5KF9+Zn7+hT7sDxmhRuKA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-optional-catch-binding": "^7.8.3" }, "engines": { @@ -1506,12 +1508,12 @@ } }, "node_modules/@babel/plugin-transform-optional-chaining": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.24.6.tgz", - "integrity": "sha512-cHbqF6l1QP11OkYTYQ+hhVx1E017O5ZcSPXk9oODpqhcAD1htsWG2NpHrrhthEO2qZomLK0FXS+u7NfrkF5aOQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-optional-chaining/-/plugin-transform-optional-chaining-7.24.7.tgz", + "integrity": "sha512-tK+0N9yd4j+x/4hxF3F0e0fu/VdcxU18y5SevtyM/PCFlQvXbR0Zmlo2eBrKtVipGNFzpq56o8WsIIKcJFUCRQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-skip-transparent-expression-wrappers": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7", "@babel/plugin-syntax-optional-chaining": "^7.8.3" }, "engines": { @@ -1522,11 +1524,11 @@ } }, "node_modules/@babel/plugin-transform-parameters": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.24.6.tgz", - "integrity": "sha512-ST7guE8vLV+vI70wmAxuZpIKzVjvFX9Qs8bl5w6tN/6gOypPWUmMQL2p7LJz5E63vEGrDhAiYetniJFyBH1RkA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-parameters/-/plugin-transform-parameters-7.24.7.tgz", + "integrity": "sha512-yGWW5Rr+sQOhK0Ot8hjDJuxU3XLRQGflvT4lhlSY0DFvdb3TwKaY26CJzHtYllU0vT9j58hc37ndFPsqT1SrzA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1536,12 +1538,12 @@ } }, "node_modules/@babel/plugin-transform-private-methods": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.24.6.tgz", - "integrity": "sha512-T9LtDI0BgwXOzyXrvgLTT8DFjCC/XgWLjflczTLXyvxbnSR/gpv0hbmzlHE/kmh9nOvlygbamLKRo6Op4yB6aw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-methods/-/plugin-transform-private-methods-7.24.7.tgz", + "integrity": "sha512-COTCOkG2hn4JKGEKBADkA8WNb35TGkkRbI5iT845dB+NyqgO8Hn+ajPbSnIQznneJTa3d30scb6iz/DhH8GsJQ==", "dependencies": { - "@babel/helper-create-class-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1551,13 +1553,13 @@ } }, "node_modules/@babel/plugin-transform-private-property-in-object": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.24.6.tgz", - "integrity": "sha512-Qu/ypFxCY5NkAnEhCF86Mvg3NSabKsh/TPpBVswEdkGl7+FbsYHy1ziRqJpwGH4thBdQHh8zx+z7vMYmcJ7iaQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-private-property-in-object/-/plugin-transform-private-property-in-object-7.24.7.tgz", + "integrity": "sha512-9z76mxwnwFxMyxZWEgdgECQglF2Q7cFLm0kMf8pGwt+GSJsY0cONKj/UuO4bOH0w/uAel3ekS4ra5CEAyJRmDA==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-create-class-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", "@babel/plugin-syntax-private-property-in-object": "^7.14.5" }, "engines": { @@ -1568,11 +1570,11 @@ } }, "node_modules/@babel/plugin-transform-property-literals": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.24.6.tgz", - "integrity": "sha512-oARaglxhRsN18OYsnPTpb8TcKQWDYNsPNmTnx5++WOAsUJ0cSC/FZVlIJCKvPbU4yn/UXsS0551CFKJhN0CaMw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-property-literals/-/plugin-transform-property-literals-7.24.7.tgz", + "integrity": "sha512-EMi4MLQSHfd2nrCqQEWxFdha2gBCqU4ZcCng4WBGZ5CJL4bBRW0ptdqqDdeirGZcpALazVVNJqRmsO8/+oNCBA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1582,11 +1584,11 @@ } }, "node_modules/@babel/plugin-transform-react-constant-elements": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-constant-elements/-/plugin-transform-react-constant-elements-7.24.6.tgz", - "integrity": "sha512-vQfyXRtG/kNIcTYRd/49uJnwvMig9X3R4XsTVXRml2RFupZFY+2RDuK+/ymb+MfX2WuIHAgUZc2xEvQrnI7QCg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-constant-elements/-/plugin-transform-react-constant-elements-7.24.7.tgz", + "integrity": "sha512-7LidzZfUXyfZ8/buRW6qIIHBY8wAZ1OrY9c/wTr8YhZ6vMPo+Uc/CVFLYY1spZrEQlD4w5u8wjqk5NQ3OVqQKA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1596,11 +1598,11 @@ } }, "node_modules/@babel/plugin-transform-react-display-name": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.24.6.tgz", - "integrity": "sha512-/3iiEEHDsJuj9QU09gbyWGSUxDboFcD7Nj6dnHIlboWSodxXAoaY/zlNMHeYAC0WsERMqgO9a7UaM77CsYgWcg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-display-name/-/plugin-transform-react-display-name-7.24.7.tgz", + "integrity": "sha512-H/Snz9PFxKsS1JLI4dJLtnJgCJRoo0AUm3chP6NYr+9En1JMKloheEiLIhlp5MDVznWo+H3AAC1Mc8lmUEpsgg==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1610,15 +1612,15 @@ } }, "node_modules/@babel/plugin-transform-react-jsx": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.24.6.tgz", - "integrity": "sha512-pCtPHhpRZHfwdA5G1Gpk5mIzMA99hv0R8S/Ket50Rw+S+8hkt3wBWqdqHaPw0CuUYxdshUgsPiLQ5fAs4ASMhw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx/-/plugin-transform-react-jsx-7.24.7.tgz", + "integrity": "sha512-+Dj06GDZEFRYvclU6k4bme55GKBEWUmByM/eoKuqg4zTNQHiApWRhQph5fxQB2wAEFvRzL1tOEj1RJ19wJrhoA==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-module-imports": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/plugin-syntax-jsx": "^7.24.6", - "@babel/types": "^7.24.6" + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-jsx": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1628,11 +1630,11 @@ } }, "node_modules/@babel/plugin-transform-react-jsx-development": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.24.6.tgz", - "integrity": "sha512-F7EsNp5StNDouSSdYyDSxh4J+xvj/JqG+Cb6s2fA+jCyHOzigG5vTwgH8tU2U8Voyiu5zCG9bAK49wTr/wPH0w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-jsx-development/-/plugin-transform-react-jsx-development-7.24.7.tgz", + "integrity": "sha512-QG9EnzoGn+Qar7rxuW+ZOsbWOt56FvvI93xInqsZDC5fsekx1AlIO4KIJ5M+D0p0SqSH156EpmZyXq630B8OlQ==", "dependencies": { - "@babel/plugin-transform-react-jsx": "^7.24.6" + "@babel/plugin-transform-react-jsx": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1642,12 +1644,12 @@ } }, "node_modules/@babel/plugin-transform-react-pure-annotations": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-pure-annotations/-/plugin-transform-react-pure-annotations-7.24.6.tgz", - "integrity": "sha512-0HoDQlFJJkXRyV2N+xOpUETbKHcouSwijRQbKWVtxsPoq5bbB30qZag9/pSc5xcWVYjTHlLsBsY+hZDnzQTPNw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-react-pure-annotations/-/plugin-transform-react-pure-annotations-7.24.7.tgz", + "integrity": "sha512-PLgBVk3fzbmEjBJ/u8kFzOqS9tUeDjiaWud/rRym/yjCo/M9cASPlnrd2ZmmZpQT40fOOrvR8jh+n8jikrOhNA==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1657,11 +1659,11 @@ } }, "node_modules/@babel/plugin-transform-regenerator": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.24.6.tgz", - "integrity": "sha512-SMDxO95I8WXRtXhTAc8t/NFQUT7VYbIWwJCJgEli9ml4MhqUMh4S6hxgH6SmAC3eAQNWCDJFxcFeEt9w2sDdXg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-regenerator/-/plugin-transform-regenerator-7.24.7.tgz", + "integrity": "sha512-lq3fvXPdimDrlg6LWBoqj+r/DEWgONuwjuOuQCSYgRroXDH/IdM1C0IZf59fL5cHLpjEH/O6opIRBbqv7ELnuA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-plugin-utils": "^7.24.7", "regenerator-transform": "^0.15.2" }, "engines": { @@ -1672,11 +1674,11 @@ } }, "node_modules/@babel/plugin-transform-reserved-words": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.24.6.tgz", - "integrity": "sha512-DcrgFXRRlK64dGE0ZFBPD5egM2uM8mgfrvTMOSB2yKzOtjpGegVYkzh3s1zZg1bBck3nkXiaOamJUqK3Syk+4A==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-reserved-words/-/plugin-transform-reserved-words-7.24.7.tgz", + "integrity": "sha512-0DUq0pHcPKbjFZCfTss/pGkYMfy3vFWydkUBd9r0GHpIyfs2eCDENvqadMycRS9wZCXR41wucAfJHJmwA0UmoQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1686,12 +1688,12 @@ } }, "node_modules/@babel/plugin-transform-runtime": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.24.6.tgz", - "integrity": "sha512-W3gQydMb0SY99y/2lV0Okx2xg/8KzmZLQsLaiCmwNRl1kKomz14VurEm+2TossUb+sRvBCnGe+wx8KtIgDtBbQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-runtime/-/plugin-transform-runtime-7.24.7.tgz", + "integrity": "sha512-YqXjrk4C+a1kZjewqt+Mmu2UuV1s07y8kqcUf4qYLnoqemhR4gRQikhdAhSVJioMjVTu6Mo6pAbaypEA3jY6fw==", "dependencies": { - "@babel/helper-module-imports": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", + "@babel/helper-module-imports": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", "babel-plugin-polyfill-corejs2": "^0.4.10", "babel-plugin-polyfill-corejs3": "^0.10.1", "babel-plugin-polyfill-regenerator": "^0.6.1", @@ -1713,11 +1715,11 @@ } }, "node_modules/@babel/plugin-transform-shorthand-properties": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.24.6.tgz", - "integrity": "sha512-xnEUvHSMr9eOWS5Al2YPfc32ten7CXdH7Zwyyk7IqITg4nX61oHj+GxpNvl+y5JHjfN3KXE2IV55wAWowBYMVw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-shorthand-properties/-/plugin-transform-shorthand-properties-7.24.7.tgz", + "integrity": "sha512-KsDsevZMDsigzbA09+vacnLpmPH4aWjcZjXdyFKGzpplxhbeB4wYtury3vglQkg6KM/xEPKt73eCjPPf1PgXBA==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1727,12 +1729,12 @@ } }, "node_modules/@babel/plugin-transform-spread": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.24.6.tgz", - "integrity": "sha512-h/2j7oIUDjS+ULsIrNZ6/TKG97FgmEk1PXryk/HQq6op4XUUUwif2f69fJrzK0wza2zjCS1xhXmouACaWV5uPA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-spread/-/plugin-transform-spread-7.24.7.tgz", + "integrity": "sha512-x96oO0I09dgMDxJaANcRyD4ellXFLLiWhuwDxKZX5g2rWP1bTPkBSwCYv96VDXVT1bD9aPj8tppr5ITIh8hBng==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-skip-transparent-expression-wrappers": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-skip-transparent-expression-wrappers": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1742,11 +1744,11 @@ } }, "node_modules/@babel/plugin-transform-sticky-regex": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.24.6.tgz", - "integrity": "sha512-fN8OcTLfGmYv7FnDrsjodYBo1DhPL3Pze/9mIIE2MGCT1KgADYIOD7rEglpLHZj8PZlC/JFX5WcD+85FLAQusw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-sticky-regex/-/plugin-transform-sticky-regex-7.24.7.tgz", + "integrity": "sha512-kHPSIJc9v24zEml5geKg9Mjx5ULpfncj0wRpYtxbvKyTtHCYDkVE3aHQ03FrpEo4gEe2vrJJS1Y9CJTaThA52g==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1756,11 +1758,11 @@ } }, "node_modules/@babel/plugin-transform-template-literals": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.24.6.tgz", - "integrity": "sha512-BJbEqJIcKwrqUP+KfUIkxz3q8VzXe2R8Wv8TaNgO1cx+nNavxn/2+H8kp9tgFSOL6wYPPEgFvU6IKS4qoGqhmg==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-template-literals/-/plugin-transform-template-literals-7.24.7.tgz", + "integrity": "sha512-AfDTQmClklHCOLxtGoP7HkeMw56k1/bTQjwsfhL6pppo/M4TOBSq+jjBUBLmV/4oeFg4GWMavIl44ZeCtmmZTw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1770,11 +1772,11 @@ } }, "node_modules/@babel/plugin-transform-typeof-symbol": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.24.6.tgz", - "integrity": "sha512-IshCXQ+G9JIFJI7bUpxTE/oA2lgVLAIK8q1KdJNoPXOpvRaNjMySGuvLfBw/Xi2/1lLo953uE8hyYSDW3TSYig==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typeof-symbol/-/plugin-transform-typeof-symbol-7.24.7.tgz", + "integrity": "sha512-VtR8hDy7YLB7+Pet9IarXjg/zgCMSF+1mNS/EQEiEaUPoFXCVsHG64SIxcaaI2zJgRiv+YmgaQESUfWAdbjzgg==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1784,14 +1786,14 @@ } }, "node_modules/@babel/plugin-transform-typescript": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.6.tgz", - "integrity": "sha512-H0i+hDLmaYYSt6KU9cZE0gb3Cbssa/oxWis7PX4ofQzbvsfix9Lbh8SRk7LCPDlLWJHUiFeHU0qRRpF/4Zv7mQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-typescript/-/plugin-transform-typescript-7.24.7.tgz", + "integrity": "sha512-iLD3UNkgx2n/HrjBesVbYX6j0yqn/sJktvbtKKgcaLIQ4bTTQ8obAypc1VpyHPD2y4Phh9zHOaAt8e/L14wCpw==", "dependencies": { - "@babel/helper-annotate-as-pure": "^7.24.6", - "@babel/helper-create-class-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/plugin-syntax-typescript": "^7.24.6" + "@babel/helper-annotate-as-pure": "^7.24.7", + "@babel/helper-create-class-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/plugin-syntax-typescript": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1801,11 +1803,11 @@ } }, "node_modules/@babel/plugin-transform-unicode-escapes": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.24.6.tgz", - "integrity": "sha512-bKl3xxcPbkQQo5eX9LjjDpU2xYHeEeNQbOhj0iPvetSzA+Tu9q/o5lujF4Sek60CM6MgYvOS/DJuwGbiEYAnLw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-escapes/-/plugin-transform-unicode-escapes-7.24.7.tgz", + "integrity": "sha512-U3ap1gm5+4edc2Q/P+9VrBNhGkfnf+8ZqppY71Bo/pzZmXhhLdqgaUl6cuB07O1+AQJtCLfaOmswiNbSQ9ivhw==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1815,12 +1817,12 @@ } }, "node_modules/@babel/plugin-transform-unicode-property-regex": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.24.6.tgz", - "integrity": "sha512-8EIgImzVUxy15cZiPii9GvLZwsy7Vxc+8meSlR3cXFmBIl5W5Tn9LGBf7CDKkHj4uVfNXCJB8RsVfnmY61iedA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-property-regex/-/plugin-transform-unicode-property-regex-7.24.7.tgz", + "integrity": "sha512-uH2O4OV5M9FZYQrwc7NdVmMxQJOCCzFeYudlZSzUAHRFeOujQefa92E74TQDVskNHCzOXoigEuoyzHDhaEaK5w==", "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1830,12 +1832,12 @@ } }, "node_modules/@babel/plugin-transform-unicode-regex": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.24.6.tgz", - "integrity": "sha512-pssN6ExsvxaKU638qcWb81RrvvgZom3jDgU/r5xFZ7TONkZGFf4MhI2ltMb8OcQWhHyxgIavEU+hgqtbKOmsPA==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-regex/-/plugin-transform-unicode-regex-7.24.7.tgz", + "integrity": "sha512-hlQ96MBZSAXUq7ltkjtu3FJCCSMx/j629ns3hA3pXnBXjanNP0LHi+JpPeA81zaWgVK1VGH95Xuy7u0RyQ8kMg==", "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1845,12 +1847,12 @@ } }, "node_modules/@babel/plugin-transform-unicode-sets-regex": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.24.6.tgz", - "integrity": "sha512-quiMsb28oXWIDK0gXLALOJRXLgICLiulqdZGOaPPd0vRT7fQp74NtdADAVu+D8s00C+0Xs0MxVP0VKF/sZEUgw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/plugin-transform-unicode-sets-regex/-/plugin-transform-unicode-sets-regex-7.24.7.tgz", + "integrity": "sha512-2G8aAvF4wy1w/AGZkemprdGMRg5o6zPNhbHVImRz3lss55TYCBd6xStN19rt8XJHq20sqV0JbyWjOWwQRwV/wg==", "dependencies": { - "@babel/helper-create-regexp-features-plugin": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6" + "@babel/helper-create-regexp-features-plugin": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1860,26 +1862,26 @@ } }, "node_modules/@babel/preset-env": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.24.6.tgz", - "integrity": "sha512-CrxEAvN7VxfjOG8JNF2Y/eMqMJbZPZ185amwGUBp8D9USK90xQmv7dLdFSa+VbD7fdIqcy/Mfv7WtzG8+/qxKg==", - "dependencies": { - "@babel/compat-data": "^7.24.6", - "@babel/helper-compilation-targets": "^7.24.6", - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-validator-option": "^7.24.6", - "@babel/plugin-bugfix-firefox-class-in-computed-class-key": "^7.24.6", - "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.24.6", - "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.24.6", - "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.24.6", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/preset-env/-/preset-env-7.24.7.tgz", + "integrity": "sha512-1YZNsc+y6cTvWlDHidMBsQZrZfEFjRIo/BZCT906PMdzOyXtSLTgqGdrpcuTDCXyd11Am5uQULtDIcCfnTc8fQ==", + "dependencies": { + "@babel/compat-data": "^7.24.7", + "@babel/helper-compilation-targets": "^7.24.7", + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-validator-option": "^7.24.7", + "@babel/plugin-bugfix-firefox-class-in-computed-class-key": "^7.24.7", + "@babel/plugin-bugfix-safari-id-destructuring-collision-in-function-expression": "^7.24.7", + "@babel/plugin-bugfix-v8-spread-parameters-in-optional-chaining": "^7.24.7", + "@babel/plugin-bugfix-v8-static-class-fields-redefine-readonly": "^7.24.7", "@babel/plugin-proposal-private-property-in-object": "7.21.0-placeholder-for-preset-env.2", "@babel/plugin-syntax-async-generators": "^7.8.4", "@babel/plugin-syntax-class-properties": "^7.12.13", "@babel/plugin-syntax-class-static-block": "^7.14.5", "@babel/plugin-syntax-dynamic-import": "^7.8.3", "@babel/plugin-syntax-export-namespace-from": "^7.8.3", - "@babel/plugin-syntax-import-assertions": "^7.24.6", - "@babel/plugin-syntax-import-attributes": "^7.24.6", + "@babel/plugin-syntax-import-assertions": "^7.24.7", + "@babel/plugin-syntax-import-attributes": "^7.24.7", "@babel/plugin-syntax-import-meta": "^7.10.4", "@babel/plugin-syntax-json-strings": "^7.8.3", "@babel/plugin-syntax-logical-assignment-operators": "^7.10.4", @@ -1891,54 +1893,54 @@ "@babel/plugin-syntax-private-property-in-object": "^7.14.5", "@babel/plugin-syntax-top-level-await": "^7.14.5", "@babel/plugin-syntax-unicode-sets-regex": "^7.18.6", - "@babel/plugin-transform-arrow-functions": "^7.24.6", - "@babel/plugin-transform-async-generator-functions": "^7.24.6", - "@babel/plugin-transform-async-to-generator": "^7.24.6", - "@babel/plugin-transform-block-scoped-functions": "^7.24.6", - "@babel/plugin-transform-block-scoping": "^7.24.6", - "@babel/plugin-transform-class-properties": "^7.24.6", - "@babel/plugin-transform-class-static-block": "^7.24.6", - "@babel/plugin-transform-classes": "^7.24.6", - "@babel/plugin-transform-computed-properties": "^7.24.6", - "@babel/plugin-transform-destructuring": "^7.24.6", - "@babel/plugin-transform-dotall-regex": "^7.24.6", - "@babel/plugin-transform-duplicate-keys": "^7.24.6", - "@babel/plugin-transform-dynamic-import": "^7.24.6", - "@babel/plugin-transform-exponentiation-operator": "^7.24.6", - "@babel/plugin-transform-export-namespace-from": "^7.24.6", - "@babel/plugin-transform-for-of": "^7.24.6", - "@babel/plugin-transform-function-name": "^7.24.6", - "@babel/plugin-transform-json-strings": "^7.24.6", - "@babel/plugin-transform-literals": "^7.24.6", - "@babel/plugin-transform-logical-assignment-operators": "^7.24.6", - "@babel/plugin-transform-member-expression-literals": "^7.24.6", - "@babel/plugin-transform-modules-amd": "^7.24.6", - "@babel/plugin-transform-modules-commonjs": "^7.24.6", - "@babel/plugin-transform-modules-systemjs": "^7.24.6", - "@babel/plugin-transform-modules-umd": "^7.24.6", - "@babel/plugin-transform-named-capturing-groups-regex": "^7.24.6", - "@babel/plugin-transform-new-target": "^7.24.6", - "@babel/plugin-transform-nullish-coalescing-operator": "^7.24.6", - "@babel/plugin-transform-numeric-separator": "^7.24.6", - "@babel/plugin-transform-object-rest-spread": "^7.24.6", - "@babel/plugin-transform-object-super": "^7.24.6", - "@babel/plugin-transform-optional-catch-binding": "^7.24.6", - "@babel/plugin-transform-optional-chaining": "^7.24.6", - "@babel/plugin-transform-parameters": "^7.24.6", - "@babel/plugin-transform-private-methods": "^7.24.6", - "@babel/plugin-transform-private-property-in-object": "^7.24.6", - "@babel/plugin-transform-property-literals": "^7.24.6", - "@babel/plugin-transform-regenerator": "^7.24.6", - "@babel/plugin-transform-reserved-words": "^7.24.6", - "@babel/plugin-transform-shorthand-properties": "^7.24.6", - "@babel/plugin-transform-spread": "^7.24.6", - "@babel/plugin-transform-sticky-regex": "^7.24.6", - "@babel/plugin-transform-template-literals": "^7.24.6", - "@babel/plugin-transform-typeof-symbol": "^7.24.6", - "@babel/plugin-transform-unicode-escapes": "^7.24.6", - "@babel/plugin-transform-unicode-property-regex": "^7.24.6", - "@babel/plugin-transform-unicode-regex": "^7.24.6", - "@babel/plugin-transform-unicode-sets-regex": "^7.24.6", + "@babel/plugin-transform-arrow-functions": "^7.24.7", + "@babel/plugin-transform-async-generator-functions": "^7.24.7", + "@babel/plugin-transform-async-to-generator": "^7.24.7", + "@babel/plugin-transform-block-scoped-functions": "^7.24.7", + "@babel/plugin-transform-block-scoping": "^7.24.7", + "@babel/plugin-transform-class-properties": "^7.24.7", + "@babel/plugin-transform-class-static-block": "^7.24.7", + "@babel/plugin-transform-classes": "^7.24.7", + "@babel/plugin-transform-computed-properties": "^7.24.7", + "@babel/plugin-transform-destructuring": "^7.24.7", + "@babel/plugin-transform-dotall-regex": "^7.24.7", + "@babel/plugin-transform-duplicate-keys": "^7.24.7", + "@babel/plugin-transform-dynamic-import": "^7.24.7", + "@babel/plugin-transform-exponentiation-operator": "^7.24.7", + "@babel/plugin-transform-export-namespace-from": "^7.24.7", + "@babel/plugin-transform-for-of": "^7.24.7", + "@babel/plugin-transform-function-name": "^7.24.7", + "@babel/plugin-transform-json-strings": "^7.24.7", + "@babel/plugin-transform-literals": "^7.24.7", + "@babel/plugin-transform-logical-assignment-operators": "^7.24.7", + "@babel/plugin-transform-member-expression-literals": "^7.24.7", + "@babel/plugin-transform-modules-amd": "^7.24.7", + "@babel/plugin-transform-modules-commonjs": "^7.24.7", + "@babel/plugin-transform-modules-systemjs": "^7.24.7", + "@babel/plugin-transform-modules-umd": "^7.24.7", + "@babel/plugin-transform-named-capturing-groups-regex": "^7.24.7", + "@babel/plugin-transform-new-target": "^7.24.7", + "@babel/plugin-transform-nullish-coalescing-operator": "^7.24.7", + "@babel/plugin-transform-numeric-separator": "^7.24.7", + "@babel/plugin-transform-object-rest-spread": "^7.24.7", + "@babel/plugin-transform-object-super": "^7.24.7", + "@babel/plugin-transform-optional-catch-binding": "^7.24.7", + "@babel/plugin-transform-optional-chaining": "^7.24.7", + "@babel/plugin-transform-parameters": "^7.24.7", + "@babel/plugin-transform-private-methods": "^7.24.7", + "@babel/plugin-transform-private-property-in-object": "^7.24.7", + "@babel/plugin-transform-property-literals": "^7.24.7", + "@babel/plugin-transform-regenerator": "^7.24.7", + "@babel/plugin-transform-reserved-words": "^7.24.7", + "@babel/plugin-transform-shorthand-properties": "^7.24.7", + "@babel/plugin-transform-spread": "^7.24.7", + "@babel/plugin-transform-sticky-regex": "^7.24.7", + "@babel/plugin-transform-template-literals": "^7.24.7", + "@babel/plugin-transform-typeof-symbol": "^7.24.7", + "@babel/plugin-transform-unicode-escapes": "^7.24.7", + "@babel/plugin-transform-unicode-property-regex": "^7.24.7", + "@babel/plugin-transform-unicode-regex": "^7.24.7", + "@babel/plugin-transform-unicode-sets-regex": "^7.24.7", "@babel/preset-modules": "0.1.6-no-external-plugins", "babel-plugin-polyfill-corejs2": "^0.4.10", "babel-plugin-polyfill-corejs3": "^0.10.4", @@ -1975,16 +1977,16 @@ } }, "node_modules/@babel/preset-react": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/preset-react/-/preset-react-7.24.6.tgz", - "integrity": "sha512-8mpzh1bWvmINmwM3xpz6ahu57mNaWavMm+wBNjQ4AFu1nghKBiIRET7l/Wmj4drXany/BBGjJZngICcD98F1iw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/preset-react/-/preset-react-7.24.7.tgz", + "integrity": "sha512-AAH4lEkpmzFWrGVlHaxJB7RLH21uPQ9+He+eFLWHmF9IuFQVugz8eAsamaW0DXRrTfco5zj1wWtpdcXJUOfsag==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-validator-option": "^7.24.6", - "@babel/plugin-transform-react-display-name": "^7.24.6", - "@babel/plugin-transform-react-jsx": "^7.24.6", - "@babel/plugin-transform-react-jsx-development": "^7.24.6", - "@babel/plugin-transform-react-pure-annotations": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-validator-option": "^7.24.7", + "@babel/plugin-transform-react-display-name": "^7.24.7", + "@babel/plugin-transform-react-jsx": "^7.24.7", + "@babel/plugin-transform-react-jsx-development": "^7.24.7", + "@babel/plugin-transform-react-pure-annotations": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -1994,15 +1996,15 @@ } }, "node_modules/@babel/preset-typescript": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.24.6.tgz", - "integrity": "sha512-U10aHPDnokCFRXgyT/MaIRTivUu2K/mu0vJlwRS9LxJmJet+PFQNKpggPyFCUtC6zWSBPjvxjnpNkAn3Uw2m5w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/preset-typescript/-/preset-typescript-7.24.7.tgz", + "integrity": "sha512-SyXRe3OdWwIwalxDg5UtJnJQO+YPcTfwiIY2B0Xlddh9o7jpWLvv8X1RthIeDOxQ+O1ML5BLPCONToObyVQVuQ==", "dependencies": { - "@babel/helper-plugin-utils": "^7.24.6", - "@babel/helper-validator-option": "^7.24.6", - "@babel/plugin-syntax-jsx": "^7.24.6", - "@babel/plugin-transform-modules-commonjs": "^7.24.6", - "@babel/plugin-transform-typescript": "^7.24.6" + "@babel/helper-plugin-utils": "^7.24.7", + "@babel/helper-validator-option": "^7.24.7", + "@babel/plugin-syntax-jsx": "^7.24.7", + "@babel/plugin-transform-modules-commonjs": "^7.24.7", + "@babel/plugin-transform-typescript": "^7.24.7" }, "engines": { "node": ">=6.9.0" @@ -2017,9 +2019,9 @@ "integrity": "sha512-x/rqGMdzj+fWZvCOYForTghzbtqPDZ5gPwaoNGHdgDfF2QA/XZbCBp4Moo5scrkAMPhB7z26XM/AaHuIJdgauA==" }, "node_modules/@babel/runtime": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.6.tgz", - "integrity": "sha512-Ja18XcETdEl5mzzACGd+DKgaGJzPTCow7EglgwTmHdwokzDFYh/MHua6lU6DV/hjF2IaOJ4oX2nqnjG7RElKOw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/runtime/-/runtime-7.24.7.tgz", + "integrity": "sha512-UwgBRMjJP+xv857DCngvqXI3Iq6J4v0wXmwc6sapg+zyhbwmQX67LUEFrkK5tbyJ30jGuG3ZvWpBiB9LCy1kWw==", "dependencies": { "regenerator-runtime": "^0.14.0" }, @@ -2028,9 +2030,9 @@ } }, "node_modules/@babel/runtime-corejs3": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.24.6.tgz", - "integrity": "sha512-tbC3o8uHK9xMgMsvUm9qGqxVpbv6yborMBLbDteHIc7JDNHsTV0vDMQ5j1O1NXvO+BDELtL9KgoWYaUVIVGt8w==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/runtime-corejs3/-/runtime-corejs3-7.24.7.tgz", + "integrity": "sha512-eytSX6JLBY6PVAeQa2bFlDx/7Mmln/gaEpsit5a3WEvjGfiIytEsgAwuIXCPM0xvw0v0cJn3ilq0/TvXrW0kgA==", "dependencies": { "core-js-pure": "^3.30.2", "regenerator-runtime": "^0.14.0" @@ -2040,31 +2042,31 @@ } }, "node_modules/@babel/template": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.24.6.tgz", - "integrity": "sha512-3vgazJlLwNXi9jhrR1ef8qiB65L1RK90+lEQwv4OxveHnqC3BfmnHdgySwRLzf6akhlOYenT+b7AfWq+a//AHw==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/template/-/template-7.24.7.tgz", + "integrity": "sha512-jYqfPrU9JTF0PmPy1tLYHW4Mp4KlgxJD9l2nP9fD6yT/ICi554DmrWBAEYpIelzjHf1msDP3PxJIRt/nFNfBig==", "dependencies": { - "@babel/code-frame": "^7.24.6", - "@babel/parser": "^7.24.6", - "@babel/types": "^7.24.6" + "@babel/code-frame": "^7.24.7", + "@babel/parser": "^7.24.7", + "@babel/types": "^7.24.7" }, "engines": { "node": ">=6.9.0" } }, "node_modules/@babel/traverse": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.24.6.tgz", - "integrity": "sha512-OsNjaJwT9Zn8ozxcfoBc+RaHdj3gFmCmYoQLUII1o6ZrUwku0BMg80FoOTPx+Gi6XhcQxAYE4xyjPTo4SxEQqw==", - "dependencies": { - "@babel/code-frame": "^7.24.6", - "@babel/generator": "^7.24.6", - "@babel/helper-environment-visitor": "^7.24.6", - "@babel/helper-function-name": "^7.24.6", - "@babel/helper-hoist-variables": "^7.24.6", - "@babel/helper-split-export-declaration": "^7.24.6", - "@babel/parser": "^7.24.6", - "@babel/types": "^7.24.6", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/traverse/-/traverse-7.24.7.tgz", + "integrity": "sha512-yb65Ed5S/QAcewNPh0nZczy9JdYXkkAbIsEo+P7BE7yO3txAY30Y/oPa3QkQ5It3xVG2kpKMg9MsdxZaO31uKA==", + "dependencies": { + "@babel/code-frame": "^7.24.7", + "@babel/generator": "^7.24.7", + "@babel/helper-environment-visitor": "^7.24.7", + "@babel/helper-function-name": "^7.24.7", + "@babel/helper-hoist-variables": "^7.24.7", + "@babel/helper-split-export-declaration": "^7.24.7", + "@babel/parser": "^7.24.7", + "@babel/types": "^7.24.7", "debug": "^4.3.1", "globals": "^11.1.0" }, @@ -2073,12 +2075,12 @@ } }, "node_modules/@babel/types": { - "version": "7.24.6", - "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.6.tgz", - "integrity": "sha512-WaMsgi6Q8zMgMth93GvWPXkhAIEobfsIkLTacoVZoK1J0CevIPGYY2Vo5YvJGqyHqXM6P4ppOYGsIRU8MM9pFQ==", + "version": "7.24.7", + "resolved": "https://registry.npmjs.org/@babel/types/-/types-7.24.7.tgz", + "integrity": "sha512-XEFXSlxiG5td2EJRe8vOmRbaXVgfcBlszKujvVmWIK/UpywWljQCfzAv3RQCGujWQ1RD4YYWEAqDXfuJiy8f5Q==", "dependencies": { - "@babel/helper-string-parser": "^7.24.6", - "@babel/helper-validator-identifier": "^7.24.6", + "@babel/helper-string-parser": "^7.24.7", + "@babel/helper-validator-identifier": "^7.24.7", "to-fast-properties": "^2.0.0" }, "engines": { @@ -2139,9 +2141,9 @@ } }, "node_modules/@docusaurus/core": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/core/-/core-3.3.2.tgz", - "integrity": "sha512-PzKMydKI3IU1LmeZQDi+ut5RSuilbXnA8QdowGeJEgU8EJjmx3rBHNT1LxQxOVqNEwpWi/csLwd9bn7rUjggPA==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/core/-/core-3.4.0.tgz", + "integrity": "sha512-g+0wwmN2UJsBqy2fQRQ6fhXruoEa62JDeEa5d8IdTJlMoaDaEDfHh7WjwGRn4opuTQWpjAwP/fbcgyHKlE+64w==", "dependencies": { "@babel/core": "^7.23.3", "@babel/generator": "^7.23.3", @@ -2153,12 +2155,12 @@ "@babel/runtime": "^7.22.6", "@babel/runtime-corejs3": "^7.22.6", "@babel/traverse": "^7.22.8", - "@docusaurus/cssnano-preset": "3.3.2", - "@docusaurus/logger": "3.3.2", - "@docusaurus/mdx-loader": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "@docusaurus/cssnano-preset": "3.4.0", + "@docusaurus/logger": "3.4.0", + "@docusaurus/mdx-loader": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "autoprefixer": "^10.4.14", "babel-loader": "^9.1.3", "babel-plugin-dynamic-import-node": "^2.3.3", @@ -2224,9 +2226,9 @@ } }, "node_modules/@docusaurus/cssnano-preset": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/cssnano-preset/-/cssnano-preset-3.3.2.tgz", - "integrity": "sha512-+5+epLk/Rp4vFML4zmyTATNc3Is+buMAL6dNjrMWahdJCJlMWMPd/8YfU+2PA57t8mlSbhLJ7vAZVy54cd1vRQ==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/cssnano-preset/-/cssnano-preset-3.4.0.tgz", + "integrity": "sha512-qwLFSz6v/pZHy/UP32IrprmH5ORce86BGtN0eBtG75PpzQJAzp9gefspox+s8IEOr0oZKuQ/nhzZ3xwyc3jYJQ==", "dependencies": { "cssnano-preset-advanced": "^6.1.2", "postcss": "^8.4.38", @@ -2238,9 +2240,9 @@ } }, "node_modules/@docusaurus/logger": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/logger/-/logger-3.3.2.tgz", - "integrity": "sha512-Ldu38GJ4P8g4guN7d7pyCOJ7qQugG7RVyaxrK8OnxuTlaImvQw33aDRwaX2eNmX8YK6v+//Z502F4sOZbHHCHQ==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/logger/-/logger-3.4.0.tgz", + "integrity": "sha512-bZwkX+9SJ8lB9kVRkXw+xvHYSMGG4bpYHKGXeXFvyVc79NMeeBSGgzd4TQLHH+DYeOJoCdl8flrFJVxlZ0wo/Q==", "dependencies": { "chalk": "^4.1.2", "tslib": "^2.6.0" @@ -2250,13 +2252,13 @@ } }, "node_modules/@docusaurus/mdx-loader": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/mdx-loader/-/mdx-loader-3.3.2.tgz", - "integrity": "sha512-AFRxj/aOk3/mfYDPxE3wTbrjeayVRvNSZP7mgMuUlrb2UlPRbSVAFX1k2RbgAJrnTSwMgb92m2BhJgYRfptN3g==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/mdx-loader/-/mdx-loader-3.4.0.tgz", + "integrity": "sha512-kSSbrrk4nTjf4d+wtBA9H+FGauf2gCax89kV8SUSJu3qaTdSIKdWERlngsiHaCFgZ7laTJ8a67UFf+xlFPtuTw==", "dependencies": { - "@docusaurus/logger": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "@docusaurus/logger": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "@mdx-js/mdx": "^3.0.0", "@slorber/remark-comment": "^1.0.0", "escape-html": "^1.0.3", @@ -2288,11 +2290,11 @@ } }, "node_modules/@docusaurus/module-type-aliases": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/module-type-aliases/-/module-type-aliases-3.3.2.tgz", - "integrity": "sha512-b/XB0TBJah5yKb4LYuJT4buFvL0MGAb0+vJDrJtlYMguRtsEBkf2nWl5xP7h4Dlw6ol0hsHrCYzJ50kNIOEclw==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/module-type-aliases/-/module-type-aliases-3.4.0.tgz", + "integrity": "sha512-A1AyS8WF5Bkjnb8s+guTDuYmUiwJzNrtchebBHpc0gz0PyHJNMaybUlSrmJjHVcGrya0LKI4YcR3lBDQfXRYLw==", "dependencies": { - "@docusaurus/types": "3.3.2", + "@docusaurus/types": "3.4.0", "@types/history": "^4.7.11", "@types/react": "*", "@types/react-router-config": "*", @@ -2305,38 +2307,18 @@ "react-dom": "*" } }, - "node_modules/@docusaurus/module-type-aliases/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-content-blog": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-content-blog/-/plugin-content-blog-3.3.2.tgz", - "integrity": "sha512-fJU+dmqp231LnwDJv+BHVWft8pcUS2xVPZdeYH6/ibH1s2wQ/sLcmUrGWyIv/Gq9Ptj8XWjRPMghlxghuPPoxg==", - "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/logger": "3.3.2", - "@docusaurus/mdx-loader": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-content-blog/-/plugin-content-blog-3.4.0.tgz", + "integrity": "sha512-vv6ZAj78ibR5Jh7XBUT4ndIjmlAxkijM3Sx5MAAzC1gyv0vupDQNhzuFg1USQmQVj3P5I6bquk12etPV3LJ+Xw==", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/logger": "3.4.0", + "@docusaurus/mdx-loader": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "cheerio": "^1.0.0-rc.12", "feed": "^4.2.2", "fs-extra": "^11.1.1", @@ -2356,39 +2338,19 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-content-blog/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-content-docs": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-content-docs/-/plugin-content-docs-3.3.2.tgz", - "integrity": "sha512-Dm1ri2VlGATTN3VGk1ZRqdRXWa1UlFubjaEL6JaxaK7IIFqN/Esjpl+Xw10R33loHcRww/H76VdEeYayaL76eg==", - "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/logger": "3.3.2", - "@docusaurus/mdx-loader": "3.3.2", - "@docusaurus/module-type-aliases": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-content-docs/-/plugin-content-docs-3.4.0.tgz", + "integrity": "sha512-HkUCZffhBo7ocYheD9oZvMcDloRnGhBMOZRyVcAQRFmZPmNqSyISlXA1tQCIxW+r478fty97XXAGjNYzBjpCsg==", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/logger": "3.4.0", + "@docusaurus/mdx-loader": "3.4.0", + "@docusaurus/module-type-aliases": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "@types/react-router-config": "^5.0.7", "combine-promises": "^1.1.0", "fs-extra": "^11.1.1", @@ -2406,36 +2368,16 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-content-docs/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-content-pages": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-content-pages/-/plugin-content-pages-3.3.2.tgz", - "integrity": "sha512-EKc9fQn5H2+OcGER8x1aR+7URtAGWySUgULfqE/M14+rIisdrBstuEZ4lUPDRrSIexOVClML82h2fDS+GSb8Ew==", - "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/mdx-loader": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-content-pages/-/plugin-content-pages-3.4.0.tgz", + "integrity": "sha512-h2+VN/0JjpR8fIkDEAoadNjfR3oLzB+v1qSXbIAKjQ46JAHx3X22n9nqS+BWSQnTnp1AjkjSvZyJMekmcwxzxg==", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/mdx-loader": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "fs-extra": "^11.1.1", "tslib": "^2.6.0", "webpack": "^5.88.1" @@ -2448,34 +2390,14 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-content-pages/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-debug": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-debug/-/plugin-debug-3.3.2.tgz", - "integrity": "sha512-oBIBmwtaB+YS0XlmZ3gCO+cMbsGvIYuAKkAopoCh0arVjtlyPbejzPrHuCoRHB9G7abjNZw7zoONOR8+8LM5+Q==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-debug/-/plugin-debug-3.4.0.tgz", + "integrity": "sha512-uV7FDUNXGyDSD3PwUaf5YijX91T5/H9SX4ErEcshzwgzWwBtK37nUWPU3ZLJfeTavX3fycTOqk9TglpOLaWkCg==", "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils": "3.3.2", + "@docusaurus/core": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils": "3.4.0", "fs-extra": "^11.1.1", "react-json-view-lite": "^1.2.0", "tslib": "^2.6.0" @@ -2488,34 +2410,14 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-debug/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-google-analytics": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-google-analytics/-/plugin-google-analytics-3.3.2.tgz", - "integrity": "sha512-jXhrEIhYPSClMBK6/IA8qf1/FBoxqGXZvg7EuBax9HaK9+kL3L0TJIlatd8jQJOMtds8mKw806TOCc3rtEad1A==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-google-analytics/-/plugin-google-analytics-3.4.0.tgz", + "integrity": "sha512-mCArluxEGi3cmYHqsgpGGt3IyLCrFBxPsxNZ56Mpur0xSlInnIHoeLDH7FvVVcPJRPSQ9/MfRqLsainRw+BojA==", "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "@docusaurus/core": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "tslib": "^2.6.0" }, "engines": { @@ -2526,34 +2428,14 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-google-analytics/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-google-gtag": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-google-gtag/-/plugin-google-gtag-3.3.2.tgz", - "integrity": "sha512-vcrKOHGbIDjVnNMrfbNpRQR1x6Jvcrb48kVzpBAOsKbj9rXZm/idjVAXRaewwobHdOrJkfWS/UJoxzK8wyLRBQ==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-google-gtag/-/plugin-google-gtag-3.4.0.tgz", + "integrity": "sha512-Dsgg6PLAqzZw5wZ4QjUYc8Z2KqJqXxHxq3vIoyoBWiLEEfigIs7wHR+oiWUQy3Zk9MIk6JTYj7tMoQU0Jm3nqA==", "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "@docusaurus/core": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "@types/gtag.js": "^0.0.12", "tslib": "^2.6.0" }, @@ -2565,34 +2447,14 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-google-gtag/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-google-tag-manager": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-google-tag-manager/-/plugin-google-tag-manager-3.3.2.tgz", - "integrity": "sha512-ldkR58Fdeks0vC+HQ+L+bGFSJsotQsipXD+iKXQFvkOfmPIV6QbHRd7IIcm5b6UtwOiK33PylNS++gjyLUmaGw==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-google-tag-manager/-/plugin-google-tag-manager-3.4.0.tgz", + "integrity": "sha512-O9tX1BTwxIhgXpOLpFDueYA9DWk69WCbDRrjYoMQtFHSkTyE7RhNgyjSPREUWJb9i+YUg3OrsvrBYRl64FCPCQ==", "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "@docusaurus/core": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "tslib": "^2.6.0" }, "engines": { @@ -2603,37 +2465,17 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-google-tag-manager/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/plugin-sitemap": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/plugin-sitemap/-/plugin-sitemap-3.3.2.tgz", - "integrity": "sha512-/ZI1+bwZBhAgC30inBsHe3qY9LOZS+79fRGkNdTcGHRMcdAp6Vw2pCd1gzlxd/xU+HXsNP6cLmTOrggmRp3Ujg==", - "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/logger": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/plugin-sitemap/-/plugin-sitemap-3.4.0.tgz", + "integrity": "sha512-+0VDvx9SmNrFNgwPoeoCha+tRoAjopwT0+pYO1xAbyLcewXSemq+eLxEa46Q1/aoOaJQ0qqHELuQM7iS2gp33Q==", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/logger": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "fs-extra": "^11.1.1", "sitemap": "^7.1.1", "tslib": "^2.6.0" @@ -2646,44 +2488,24 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/plugin-sitemap/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/preset-classic": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/preset-classic/-/preset-classic-3.3.2.tgz", - "integrity": "sha512-1SDS7YIUN1Pg3BmD6TOTjhB7RSBHJRpgIRKx9TpxqyDrJ92sqtZhomDc6UYoMMLQNF2wHFZZVGFjxJhw2VpL+Q==", - "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/plugin-content-blog": "3.3.2", - "@docusaurus/plugin-content-docs": "3.3.2", - "@docusaurus/plugin-content-pages": "3.3.2", - "@docusaurus/plugin-debug": "3.3.2", - "@docusaurus/plugin-google-analytics": "3.3.2", - "@docusaurus/plugin-google-gtag": "3.3.2", - "@docusaurus/plugin-google-tag-manager": "3.3.2", - "@docusaurus/plugin-sitemap": "3.3.2", - "@docusaurus/theme-classic": "3.3.2", - "@docusaurus/theme-common": "3.3.2", - "@docusaurus/theme-search-algolia": "3.3.2", - "@docusaurus/types": "3.3.2" + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/preset-classic/-/preset-classic-3.4.0.tgz", + "integrity": "sha512-Ohj6KB7siKqZaQhNJVMBBUzT3Nnp6eTKqO+FXO3qu/n1hJl3YLwVKTWBg28LF7MWrKu46UuYavwMRxud0VyqHg==", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/plugin-content-blog": "3.4.0", + "@docusaurus/plugin-content-docs": "3.4.0", + "@docusaurus/plugin-content-pages": "3.4.0", + "@docusaurus/plugin-debug": "3.4.0", + "@docusaurus/plugin-google-analytics": "3.4.0", + "@docusaurus/plugin-google-gtag": "3.4.0", + "@docusaurus/plugin-google-tag-manager": "3.4.0", + "@docusaurus/plugin-sitemap": "3.4.0", + "@docusaurus/theme-classic": "3.4.0", + "@docusaurus/theme-common": "3.4.0", + "@docusaurus/theme-search-algolia": "3.4.0", + "@docusaurus/types": "3.4.0" }, "engines": { "node": ">=18.0" @@ -2693,43 +2515,23 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/preset-classic/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/theme-classic": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/theme-classic/-/theme-classic-3.3.2.tgz", - "integrity": "sha512-gepHFcsluIkPb4Im9ukkiO4lXrai671wzS3cKQkY9BXQgdVwsdPf/KS0Vs4Xlb0F10fTz+T3gNjkxNEgSN9M0A==", - "dependencies": { - "@docusaurus/core": "3.3.2", - "@docusaurus/mdx-loader": "3.3.2", - "@docusaurus/module-type-aliases": "3.3.2", - "@docusaurus/plugin-content-blog": "3.3.2", - "@docusaurus/plugin-content-docs": "3.3.2", - "@docusaurus/plugin-content-pages": "3.3.2", - "@docusaurus/theme-common": "3.3.2", - "@docusaurus/theme-translations": "3.3.2", - "@docusaurus/types": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/theme-classic/-/theme-classic-3.4.0.tgz", + "integrity": "sha512-0IPtmxsBYv2adr1GnZRdMkEQt1YW6tpzrUPj02YxNpvJ5+ju4E13J5tB4nfdaen/tfR1hmpSPlTFPvTf4kwy8Q==", + "dependencies": { + "@docusaurus/core": "3.4.0", + "@docusaurus/mdx-loader": "3.4.0", + "@docusaurus/module-type-aliases": "3.4.0", + "@docusaurus/plugin-content-blog": "3.4.0", + "@docusaurus/plugin-content-docs": "3.4.0", + "@docusaurus/plugin-content-pages": "3.4.0", + "@docusaurus/theme-common": "3.4.0", + "@docusaurus/theme-translations": "3.4.0", + "@docusaurus/types": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "@mdx-js/react": "^3.0.0", "clsx": "^2.0.0", "copy-text-to-clipboard": "^3.2.0", @@ -2752,38 +2554,18 @@ "react-dom": "^18.0.0" } }, - "node_modules/@docusaurus/theme-classic/node_modules/@docusaurus/types": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.3.2.tgz", - "integrity": "sha512-5p201S7AZhliRxTU7uMKtSsoC8mgPA9bs9b5NQg1IRdRxJfflursXNVsgc3PcMqiUTul/v1s3k3rXXFlRE890w==", - "dependencies": { - "@mdx-js/mdx": "^3.0.0", - "@types/history": "^4.7.11", - "@types/react": "*", - "commander": "^5.1.0", - "joi": "^17.9.2", - "react-helmet-async": "^1.3.0", - "utility-types": "^3.10.0", - "webpack": "^5.88.1", - "webpack-merge": "^5.9.0" - }, - "peerDependencies": { - "react": "^18.0.0", - "react-dom": "^18.0.0" - } - }, "node_modules/@docusaurus/theme-common": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/theme-common/-/theme-common-3.3.2.tgz", - "integrity": "sha512-kXqSaL/sQqo4uAMQ4fHnvRZrH45Xz2OdJ3ABXDS7YVGPSDTBC8cLebFrRR4YF9EowUHto1UC/EIklJZQMG/usA==", - "dependencies": { - "@docusaurus/mdx-loader": "3.3.2", - "@docusaurus/module-type-aliases": "3.3.2", - "@docusaurus/plugin-content-blog": "3.3.2", - "@docusaurus/plugin-content-docs": "3.3.2", - "@docusaurus/plugin-content-pages": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/theme-common/-/theme-common-3.4.0.tgz", + "integrity": "sha512-0A27alXuv7ZdCg28oPE8nH/Iz73/IUejVaCazqu9elS4ypjiLhK3KfzdSQBnL/g7YfHSlymZKdiOHEo8fJ0qMA==", + "dependencies": { + "@docusaurus/mdx-loader": "3.4.0", + "@docusaurus/module-type-aliases": "3.4.0", + "@docusaurus/plugin-content-blog": "3.4.0", + "@docusaurus/plugin-content-docs": "3.4.0", + "@docusaurus/plugin-content-pages": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", "@types/history": "^4.7.11", "@types/react": "*", "@types/react-router-config": "*", @@ -2802,18 +2584,18 @@ } }, "node_modules/@docusaurus/theme-search-algolia": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/theme-search-algolia/-/theme-search-algolia-3.3.2.tgz", - "integrity": "sha512-qLkfCl29VNBnF1MWiL9IyOQaHxUvicZp69hISyq/xMsNvFKHFOaOfk9xezYod2Q9xx3xxUh9t/QPigIei2tX4w==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/theme-search-algolia/-/theme-search-algolia-3.4.0.tgz", + "integrity": "sha512-aiHFx7OCw4Wck1z6IoShVdUWIjntC8FHCw9c5dR8r3q4Ynh+zkS8y2eFFunN/DL6RXPzpnvKCg3vhLQYJDmT9Q==", "dependencies": { "@docsearch/react": "^3.5.2", - "@docusaurus/core": "3.3.2", - "@docusaurus/logger": "3.3.2", - "@docusaurus/plugin-content-docs": "3.3.2", - "@docusaurus/theme-common": "3.3.2", - "@docusaurus/theme-translations": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-validation": "3.3.2", + "@docusaurus/core": "3.4.0", + "@docusaurus/logger": "3.4.0", + "@docusaurus/plugin-content-docs": "3.4.0", + "@docusaurus/theme-common": "3.4.0", + "@docusaurus/theme-translations": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-validation": "3.4.0", "algoliasearch": "^4.18.0", "algoliasearch-helper": "^3.13.3", "clsx": "^2.0.0", @@ -2832,9 +2614,9 @@ } }, "node_modules/@docusaurus/theme-translations": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/theme-translations/-/theme-translations-3.3.2.tgz", - "integrity": "sha512-bPuiUG7Z8sNpGuTdGnmKl/oIPeTwKr0AXLGu9KaP6+UFfRZiyWbWE87ti97RrevB2ffojEdvchNujparR3jEZQ==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/theme-translations/-/theme-translations-3.4.0.tgz", + "integrity": "sha512-zSxCSpmQCCdQU5Q4CnX/ID8CSUUI3fvmq4hU/GNP/XoAWtXo9SAVnM3TzpU8Gb//H3WCsT8mJcTfyOk3d9ftNg==", "dependencies": { "fs-extra": "^11.1.1", "tslib": "^2.6.0" @@ -2844,11 +2626,11 @@ } }, "node_modules/@docusaurus/types": { - "version": "3.0.1", - "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.0.1.tgz", - "integrity": "sha512-plyX2iU1tcUsF46uQ01pAd4JhexR7n0iiQ5MSnBFX6M6NSJgDYdru/i1/YNPKOnQHBoXGLHv0dNT6OAlDWNjrg==", - "devOptional": true, + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/types/-/types-3.4.0.tgz", + "integrity": "sha512-4jcDO8kXi5Cf9TcyikB/yKmz14f2RZ2qTRerbHAsS+5InE9ZgSLBNLsewtFTcTOXSVcbU3FoGOzcNWAmU1TR0A==", "dependencies": { + "@mdx-js/mdx": "^3.0.0", "@types/history": "^4.7.11", "@types/react": "*", "commander": "^5.1.0", @@ -2864,12 +2646,12 @@ } }, "node_modules/@docusaurus/utils": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/utils/-/utils-3.3.2.tgz", - "integrity": "sha512-f4YMnBVymtkSxONv4Y8js3Gez9IgHX+Lcg6YRMOjVbq8sgCcdYK1lf6SObAuz5qB/mxiSK7tW0M9aaiIaUSUJg==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/utils/-/utils-3.4.0.tgz", + "integrity": "sha512-fRwnu3L3nnWaXOgs88BVBmG1yGjcQqZNHG+vInhEa2Sz2oQB+ZjbEMO5Rh9ePFpZ0YDiDUhpaVjwmS+AU2F14g==", "dependencies": { - "@docusaurus/logger": "3.3.2", - "@docusaurus/utils-common": "3.3.2", + "@docusaurus/logger": "3.4.0", + "@docusaurus/utils-common": "3.4.0", "@svgr/webpack": "^8.1.0", "escape-string-regexp": "^4.0.0", "file-loader": "^6.2.0", @@ -2886,6 +2668,7 @@ "shelljs": "^0.8.5", "tslib": "^2.6.0", "url-loader": "^4.1.1", + "utility-types": "^3.10.0", "webpack": "^5.88.1" }, "engines": { @@ -2901,9 +2684,9 @@ } }, "node_modules/@docusaurus/utils-common": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/utils-common/-/utils-common-3.3.2.tgz", - "integrity": "sha512-QWFTLEkPYsejJsLStgtmetMFIA3pM8EPexcZ4WZ7b++gO5jGVH7zsipREnCHzk6+eDgeaXfkR6UPaTt86bp8Og==", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/utils-common/-/utils-common-3.4.0.tgz", + "integrity": "sha512-NVx54Wr4rCEKsjOH5QEVvxIqVvm+9kh7q8aYTU5WzUU9/Hctd6aTrcZ3G0Id4zYJ+AeaG5K5qHA4CY5Kcm2iyQ==", "dependencies": { "tslib": "^2.6.0" }, @@ -2920,80 +2703,23 @@ } }, "node_modules/@docusaurus/utils-validation": { - "version": "3.3.2", - "resolved": "https://registry.npmjs.org/@docusaurus/utils-validation/-/utils-validation-3.3.2.tgz", - "integrity": "sha512-itDgFs5+cbW9REuC7NdXals4V6++KifgVMzoGOOOSIifBQw+8ULhy86u5e1lnptVL0sv8oAjq2alO7I40GR7pA==", - "dependencies": { - "@docusaurus/logger": "3.3.2", - "@docusaurus/utils": "3.3.2", - "@docusaurus/utils-common": "3.3.2", + "version": "3.4.0", + "resolved": "https://registry.npmjs.org/@docusaurus/utils-validation/-/utils-validation-3.4.0.tgz", + "integrity": "sha512-hYQ9fM+AXYVTWxJOT1EuNaRnrR2WGpRdLDQG07O8UOpsvCPWUVOeo26Rbm0JWY2sGLfzAb+tvJ62yF+8F+TV0g==", + "dependencies": { + "@docusaurus/logger": "3.4.0", + "@docusaurus/utils": "3.4.0", + "@docusaurus/utils-common": "3.4.0", + "fs-extra": "^11.2.0", "joi": "^17.9.2", "js-yaml": "^4.1.0", + "lodash": "^4.17.21", "tslib": "^2.6.0" }, "engines": { "node": ">=18.0" } }, - "node_modules/@fortawesome/fontawesome-common-types": { - "version": "6.5.2", - "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-common-types/-/fontawesome-common-types-6.5.2.tgz", - "integrity": "sha512-gBxPg3aVO6J0kpfHNILc+NMhXnqHumFxOmjYCFfOiLZfwhnnfhtsdA2hfJlDnj+8PjAs6kKQPenOTKj3Rf7zHw==", - "hasInstallScript": true, - "license": "MIT", - "engines": { - "node": ">=6" - } - }, - "node_modules/@fortawesome/fontawesome-free": { - "version": "6.5.2", - "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-free/-/fontawesome-free-6.5.2.tgz", - "integrity": "sha512-hRILoInAx8GNT5IMkrtIt9blOdrqHOnPBH+k70aWUAqPZPgopb9G5EQJFpaBx/S8zp2fC+mPW349Bziuk1o28Q==", - "hasInstallScript": true, - "license": "(CC-BY-4.0 AND OFL-1.1 AND MIT)", - "engines": { - "node": ">=6" - } - }, - "node_modules/@fortawesome/fontawesome-svg-core": { - "version": "6.5.2", - "resolved": "https://registry.npmjs.org/@fortawesome/fontawesome-svg-core/-/fontawesome-svg-core-6.5.2.tgz", - "integrity": "sha512-5CdaCBGl8Rh9ohNdxeeTMxIj8oc3KNBgIeLMvJosBMdslK/UnEB8rzyDRrbKdL1kDweqBPo4GT9wvnakHWucZw==", - "hasInstallScript": true, - "license": "MIT", - "dependencies": { - "@fortawesome/fontawesome-common-types": "6.5.2" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@fortawesome/free-brands-svg-icons": { - "version": "6.5.2", - "resolved": "https://registry.npmjs.org/@fortawesome/free-brands-svg-icons/-/free-brands-svg-icons-6.5.2.tgz", - "integrity": "sha512-zi5FNYdmKLnEc0jc0uuHH17kz/hfYTg4Uei0wMGzcoCL/4d3WM3u1VMc0iGGa31HuhV5i7ZK8ZlTCQrHqRHSGQ==", - "hasInstallScript": true, - "license": "(CC-BY-4.0 AND MIT)", - "dependencies": { - "@fortawesome/fontawesome-common-types": "6.5.2" - }, - "engines": { - "node": ">=6" - } - }, - "node_modules/@fortawesome/react-fontawesome": { - "version": "0.2.2", - "resolved": "https://registry.npmjs.org/@fortawesome/react-fontawesome/-/react-fontawesome-0.2.2.tgz", - "integrity": "sha512-EnkrprPNqI6SXJl//m29hpaNzOp1bruISWaOiRtkMi/xSvHJlzc2j2JAYS7egxt/EbjSNV/k6Xy0AQI6vB2+1g==", - "license": "MIT", - "dependencies": { - "prop-types": "^15.8.1" - }, - "peerDependencies": { - "@fortawesome/fontawesome-svg-core": "~1 || ~6", - "react": ">=16.3" - } - }, "node_modules/@hapi/hoek": { "version": "9.3.0", "resolved": "https://registry.npmjs.org/@hapi/hoek/-/hoek-9.3.0.tgz", @@ -3614,9 +3340,9 @@ } }, "node_modules/@types/express-serve-static-core": { - "version": "4.19.1", - "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.19.1.tgz", - "integrity": "sha512-ej0phymbFLoCB26dbbq5PGScsf2JAJ4IJHjG10LalgUV36XKTmA4GdA+PVllKvRk0sEKt64X8975qFnkSi0hqA==", + "version": "4.19.5", + "resolved": "https://registry.npmjs.org/@types/express-serve-static-core/-/express-serve-static-core-4.19.5.tgz", + "integrity": "sha512-y6W03tvrACO72aijJ5uF02FRq5cgDR9lUxddQ8vyF+GvmjJQqbzDcJngEjURc+ZsG31VI3hODNZJ2URj86pzmg==", "dependencies": { "@types/node": "*", "@types/qs": "*", @@ -3715,9 +3441,9 @@ "integrity": "sha512-nG96G3Wp6acyAgJqGasjODb+acrI7KltPiRxzHPXnP3NgI28bpQDRv53olbqGXbfcgF5aiiHmO3xpwEpS5Ld9g==" }, "node_modules/@types/node": { - "version": "20.12.12", - "resolved": "https://registry.npmjs.org/@types/node/-/node-20.12.12.tgz", - "integrity": "sha512-eWLDGF/FOSPtAvEqeRAQ4C8LSA7M1I7i0ky1I8U7kD1J5ITyW3AsRhQrKVoWf5pFKZ2kILsEGJhsI9r93PYnOw==", + "version": "20.14.8", + "resolved": "https://registry.npmjs.org/@types/node/-/node-20.14.8.tgz", + "integrity": "sha512-DO+2/jZinXfROG7j7WKFn/3C6nFwxy2lLpgLjEXJz+0XKphZlTLJ14mo8Vfg8X5BWN6XjyESXq+LcYdT7tR3bA==", "dependencies": { "undici-types": "~5.26.4" } @@ -4045,9 +3771,9 @@ } }, "node_modules/acorn": { - "version": "8.11.3", - "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.11.3.tgz", - "integrity": "sha512-Y9rRfJG5jcKOE0CLisYbojUjIrIEE7AGMzA/Sm4BslANhbS+cDMpgBdcPT91oJ7OuJ9hYJBx59RjbhxVnrF8Xg==", + "version": "8.12.0", + "resolved": "https://registry.npmjs.org/acorn/-/acorn-8.12.0.tgz", + "integrity": "sha512-RTvkC4w+KNXrM39/lWCUaG0IbRkWdCv7W/IOW9oU6SawyxulvkQy5HQPVTKxEjczcUvapcrw3cFx/60VN/NRNw==", "bin": { "acorn": "bin/acorn" }, @@ -4055,10 +3781,10 @@ "node": ">=0.4.0" } }, - "node_modules/acorn-import-assertions": { - "version": "1.9.0", - "resolved": "https://registry.npmjs.org/acorn-import-assertions/-/acorn-import-assertions-1.9.0.tgz", - "integrity": "sha512-cmMwop9x+8KFhxvKrKfPYmN6/pKTYYHBqLa0DfvVZcKMJWNyWLnaqND7dx/qn66R7ewM1UX5XMaDVP5wlVTaVA==", + "node_modules/acorn-import-attributes": { + "version": "1.9.5", + "resolved": "https://registry.npmjs.org/acorn-import-attributes/-/acorn-import-attributes-1.9.5.tgz", + "integrity": "sha512-n02Vykv5uA3eHGM/Z2dQrcD56kL8TyDb2p1+0P83PClMnC/nc+anbQRhIOWnSq4Ke/KvDPrY3C9hDtC/A3eHnQ==", "peerDependencies": { "acorn": "^8" } @@ -4072,9 +3798,12 @@ } }, "node_modules/acorn-walk": { - "version": "8.3.2", - "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.2.tgz", - "integrity": "sha512-cjkyv4OtNCIeqhHrfS81QWXoCBPExR/J62oyEqepVw8WaQeSqpW2uhuLPh1m9eWhDuOo/jUXVTlifvesOWp/4A==", + "version": "8.3.3", + "resolved": "https://registry.npmjs.org/acorn-walk/-/acorn-walk-8.3.3.tgz", + "integrity": "sha512-MxXdReSRhGO7VlFe1bRG/oI7/mdLV9B9JJT0N8vZOhF7gFRR5l3M8W9G8JxmKV+JC5mGqJ0QvqfSOLsCPa4nUw==", + "dependencies": { + "acorn": "^8.11.0" + }, "engines": { "node": ">=0.4.0" } @@ -4100,9 +3829,9 @@ } }, "node_modules/ajv": { - "version": "8.14.0", - "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.14.0.tgz", - "integrity": "sha512-oYs1UUtO97ZO2lJ4bwnWeQW8/zvOIQLGKcvPTsWmvc2SYgBb+upuNS5NxoLaMU4h8Ju3Nbj6Cq8mD2LQoqVKFA==", + "version": "8.16.0", + "resolved": "https://registry.npmjs.org/ajv/-/ajv-8.16.0.tgz", + "integrity": "sha512-F0twR8U1ZU67JIEtekUcLkXkoO5mMMmgGD8sK/xUFzJ805jxHQl92hImFAqqXMyMYjSPOyUPAwHYhB72g5sTXw==", "dependencies": { "fast-deep-equal": "^3.1.3", "json-schema-traverse": "^1.0.0", @@ -4164,9 +3893,9 @@ } }, "node_modules/algoliasearch-helper": { - "version": "3.20.0", - "resolved": "https://registry.npmjs.org/algoliasearch-helper/-/algoliasearch-helper-3.20.0.tgz", - "integrity": "sha512-6EVhAmVug0+hdRHWbubF7hLHHhLoQ8NjLk6iS6d4k5chWawpS5EDexrF6Jx/hPZvUKIeNrzsbTpjAkcvrjNLHg==", + "version": "3.22.1", + "resolved": "https://registry.npmjs.org/algoliasearch-helper/-/algoliasearch-helper-3.22.1.tgz", + "integrity": "sha512-fSxJ4YreH4kOME9CnKazbAn2tK/rvBoV37ETd6nTt4j7QfkcnW+c+F22WfuE9Q/sRpvOMnUwU/BXAVEiwW7p/w==", "dependencies": { "@algolia/events": "^4.0.1" }, @@ -4526,9 +4255,9 @@ } }, "node_modules/browserslist": { - "version": "4.23.0", - "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.0.tgz", - "integrity": "sha512-QW8HiM1shhT2GuzkvklfjcKDiWFXHOeFCIA/huJPwHsslwcydgk7X+z2zXpEijP98UCY7HbubZt5J2Zgvf0CaQ==", + "version": "4.23.1", + "resolved": "https://registry.npmjs.org/browserslist/-/browserslist-4.23.1.tgz", + "integrity": "sha512-TUfofFo/KsK/bWZ9TWQ5O26tsWW4Uhmt8IYklbnUa70udB6P2wA7w7o4PY4muaEPBQaAX+CEnmmIA41NVHtPVw==", "funding": [ { "type": "opencollective", @@ -4544,10 +4273,10 @@ } ], "dependencies": { - "caniuse-lite": "^1.0.30001587", - "electron-to-chromium": "^1.4.668", + "caniuse-lite": "^1.0.30001629", + "electron-to-chromium": "^1.4.796", "node-releases": "^2.0.14", - "update-browserslist-db": "^1.0.13" + "update-browserslist-db": "^1.0.16" }, "bin": { "browserslist": "cli.js" @@ -4652,9 +4381,9 @@ } }, "node_modules/caniuse-lite": { - "version": "1.0.30001621", - "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001621.tgz", - "integrity": "sha512-+NLXZiviFFKX0fk8Piwv3PfLPGtRqJeq2TiNoUff/qB5KJgwecJTvCXDpmlyP/eCI/GUEmp/h/y5j0yckiiZrA==", + "version": "1.0.30001636", + "resolved": "https://registry.npmjs.org/caniuse-lite/-/caniuse-lite-1.0.30001636.tgz", + "integrity": "sha512-bMg2vmr8XBsbL6Lr0UHXy/21m84FTxDLWn2FSqMd5PrlbMxwJlQnC2YWYxVgp66PZE+BBNF2jYQUBKCo1FDeZg==", "funding": [ { "type": "opencollective", @@ -4798,9 +4527,9 @@ } }, "node_modules/chrome-trace-event": { - "version": "1.0.3", - "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.3.tgz", - "integrity": "sha512-p3KULyQg4S7NIHixdwbGX+nFHkoBiA4YQmyWtjb8XngSKV124nJmRysgAeujbUVb15vh+RvFUfCPqU7rXk+hZg==", + "version": "1.0.4", + "resolved": "https://registry.npmjs.org/chrome-trace-event/-/chrome-trace-event-1.0.4.tgz", + "integrity": "sha512-rNjApaLzuwaOTjCiT8lSDdGN1APCiqkChLMJxJPWLunPAt5fy8xgU9/jNOchV84wfIxrA0lRQB7oCT8jrn/wrQ==", "engines": { "node": ">=6.0" } @@ -5553,9 +5282,9 @@ "integrity": "sha512-XRRe6Glud4rd/ZGQfiV1ruXSfbvfJedlV9Y6zOlP+2K04vBYiJEte6stfFkCP03aMnY5tsipamumUjL14fofug==" }, "node_modules/debug": { - "version": "4.3.4", - "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.4.tgz", - "integrity": "sha512-PRWFHuSU3eDtQJPvnNY7Jcket1j0t5OuOsFzPPzsekD52Zl8qUfFIPEiswXqIvHWGVHOgX+7G/vCNNhehwxfkQ==", + "version": "4.3.5", + "resolved": "https://registry.npmjs.org/debug/-/debug-4.3.5.tgz", + "integrity": "sha512-pt0bNEmneDIvdL1Xsd9oDQ/wrQRkXDT4AUWlNZNPKvW5x/jyO9VFXkJUP07vQ2upmw5PlaITaPKc31jK13V+jg==", "dependencies": { "ms": "2.1.2" }, @@ -5900,17 +5629,6 @@ "node": ">=8" } }, - "node_modules/dotenv": { - "version": "16.4.5", - "resolved": "https://registry.npmjs.org/dotenv/-/dotenv-16.4.5.tgz", - "integrity": "sha512-ZmdL2rui+eB2YwhsWzjInR8LldtZHGDoQ1ugH85ppHKwpUHL7j7rN0Ti9NCnGiQbhaZ11FpR+7ao1dNsmduNUg==", - "engines": { - "node": ">=12" - }, - "funding": { - "url": "https://dotenvx.com" - } - }, "node_modules/duplexer": { "version": "0.1.2", "resolved": "https://registry.npmjs.org/duplexer/-/duplexer-0.1.2.tgz", @@ -5927,9 +5645,9 @@ "integrity": "sha512-WMwm9LhRUo+WUaRN+vRuETqG89IgZphVSNkdFgeb6sS/E4OrDIN7t48CAewSHXc6C8lefD8KKfr5vY61brQlow==" }, "node_modules/electron-to-chromium": { - "version": "1.4.783", - "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.783.tgz", - "integrity": "sha512-bT0jEz/Xz1fahQpbZ1D7LgmPYZ3iHVY39NcWWro1+hA2IvjiPeaXtfSqrQ+nXjApMvQRE2ASt1itSLRrebHMRQ==" + "version": "1.4.811", + "resolved": "https://registry.npmjs.org/electron-to-chromium/-/electron-to-chromium-1.4.811.tgz", + "integrity": "sha512-CDyzcJ5XW78SHzsIOdn27z8J4ist8eaFLhdto2hSMSJQgsiwvbv2fbizcKUICryw1Wii1TI/FEkvzvJsR3awrA==" }, "node_modules/emoji-regex": { "version": "9.2.2", @@ -5967,9 +5685,9 @@ } }, "node_modules/enhanced-resolve": { - "version": "5.16.1", - "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.16.1.tgz", - "integrity": "sha512-4U5pNsuDl0EhuZpq46M5xPslstkviJuhrdobaRDBk2Jy2KO37FDAJl4lb2KlNabxT0m4MTK2UHNrsAcphE8nyw==", + "version": "5.17.0", + "resolved": "https://registry.npmjs.org/enhanced-resolve/-/enhanced-resolve-5.17.0.tgz", + "integrity": "sha512-dwDPwZL0dmye8Txp2gzFmA6sxALaSvdRDjPH0viLcKrtlOL3tw62nWWweVD1SdILDTJrbrL6tdWVN58Wo6U3eA==", "dependencies": { "graceful-fs": "^4.2.4", "tapable": "^2.2.0" @@ -6017,9 +5735,9 @@ } }, "node_modules/es-module-lexer": { - "version": "1.5.3", - "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.5.3.tgz", - "integrity": "sha512-i1gCgmR9dCl6Vil6UKPI/trA69s08g/syhiDK9TG0Nf1RJjjFI+AzoWW7sPufzkgYAn861skuCwJa0pIIHYxvg==" + "version": "1.5.4", + "resolved": "https://registry.npmjs.org/es-module-lexer/-/es-module-lexer-1.5.4.tgz", + "integrity": "sha512-MVNK56NiMrOwitFB7cqDwq0CQutbw+0BvLshJSse0MUNU+y1FC3bUS/AQg7oUng+/wKrrki7JfmwtVHkVfPLlw==" }, "node_modules/escalade": { "version": "3.1.2", @@ -6158,12 +5876,11 @@ } }, "node_modules/estree-util-value-to-estree": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/estree-util-value-to-estree/-/estree-util-value-to-estree-3.1.1.tgz", - "integrity": "sha512-5mvUrF2suuv5f5cGDnDphIy4/gW86z82kl5qG6mM9z04SEQI4FB5Apmaw/TGEf3l55nLtMs5s51dmhUzvAHQCA==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/estree-util-value-to-estree/-/estree-util-value-to-estree-3.1.2.tgz", + "integrity": "sha512-S0gW2+XZkmsx00tU2uJ4L9hUT7IFabbml9pHh2WQqFmAbxit++YGZne0sKJbNwkj9Wvg9E4uqWl4nCIFQMmfag==", "dependencies": { - "@types/estree": "^1.0.0", - "is-plain-obj": "^4.0.0" + "@types/estree": "^1.0.0" }, "funding": { "url": "https://github.com/sponsors/remcohaszing" @@ -7177,9 +6894,9 @@ } }, "node_modules/hast-util-raw": { - "version": "9.0.3", - "resolved": "https://registry.npmjs.org/hast-util-raw/-/hast-util-raw-9.0.3.tgz", - "integrity": "sha512-ICWvVOF2fq4+7CMmtCPD5CM4QKjPbHpPotE6+8tDooV0ZuyJVUzHsrNX+O5NaRbieTf0F7FfeBOMAwi6Td0+yQ==", + "version": "9.0.4", + "resolved": "https://registry.npmjs.org/hast-util-raw/-/hast-util-raw-9.0.4.tgz", + "integrity": "sha512-LHE65TD2YiNsHD3YuXcKPHXPLuYh/gjp12mOfU8jxSrm1f/yJpsb0F/KKljS6U9LJoP0Ux+tCe8iJ2AsPzTdgA==", "dependencies": { "@types/hast": "^3.0.0", "@types/unist": "^3.0.0", @@ -7825,11 +7542,14 @@ } }, "node_modules/is-core-module": { - "version": "2.13.1", - "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.13.1.tgz", - "integrity": "sha512-hHrIjvZsftOsvKSn2TRYl63zvxsgE0K+0mYMoH6gD4omR5IWB2KynivBQczo3+wF1cCkjzvptnI9Q0sPU66ilw==", + "version": "2.14.0", + "resolved": "https://registry.npmjs.org/is-core-module/-/is-core-module-2.14.0.tgz", + "integrity": "sha512-a5dFJih5ZLYlRtDc0dZWP7RiKr6xIKzmn/oAYCDvdLThadVgyJwlaoQPmRtMSpz+rk0OGAgIu+TcM9HUF0fk1A==", "dependencies": { - "hasown": "^2.0.0" + "hasown": "^2.0.2" + }, + "engines": { + "node": ">= 0.4" }, "funding": { "url": "https://github.com/sponsors/ljharb" @@ -8104,17 +7824,17 @@ } }, "node_modules/jiti": { - "version": "1.21.0", - "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.0.tgz", - "integrity": "sha512-gFqAIbuKyyso/3G2qhiO2OM6shY6EPP/R0+mkDbyspxKazh8BXDC5FiFsUjlczgdNz/vfra0da2y+aHrusLG/Q==", + "version": "1.21.6", + "resolved": "https://registry.npmjs.org/jiti/-/jiti-1.21.6.tgz", + "integrity": "sha512-2yTgeWTWzMWkHu6Jp9NKgePDaYHbntiwvYuuJLbbN9vl7DC9DvXKOB2BC3ZZ92D3cvV/aflH0osDfwpHepQ53w==", "bin": { "jiti": "bin/jiti.js" } }, "node_modules/joi": { - "version": "17.13.1", - "resolved": "https://registry.npmjs.org/joi/-/joi-17.13.1.tgz", - "integrity": "sha512-vaBlIKCyo4FCUtCm7Eu4QZd/q02bWcxfUO6YSXAZOWF6gzcLBeba8kwotUdYJjDLW8Cz8RywsSOqiNJZW0mNvg==", + "version": "17.13.3", + "resolved": "https://registry.npmjs.org/joi/-/joi-17.13.3.tgz", + "integrity": "sha512-otDA4ldcIx+ZXsKHWmp0YizCweVRZG96J10b0FevjfuncLO1oX59THoAmHkNubYJ+9gWsYsp5k8v4ib6oDv1fA==", "dependencies": { "@hapi/hoek": "^9.3.0", "@hapi/topo": "^5.1.0", @@ -8226,9 +7946,9 @@ } }, "node_modules/launch-editor": { - "version": "2.6.1", - "resolved": "https://registry.npmjs.org/launch-editor/-/launch-editor-2.6.1.tgz", - "integrity": "sha512-eB/uXmFVpY4zezmGp5XtU21kwo7GBbKB+EQ+UZeWtGb9yAM5xt/Evk+lYH3eRNAtId+ej4u7TYPFZ07w4s7rRw==", + "version": "2.8.0", + "resolved": "https://registry.npmjs.org/launch-editor/-/launch-editor-2.8.0.tgz", + "integrity": "sha512-vJranOAJrI/llyWGRQqiDM+adrw+k83fvmmx3+nV47g3+36xM15jE+zyZ6Ffel02+xSvuM0b2GDRosXZkbb6wA==", "dependencies": { "picocolors": "^1.0.0", "shell-quote": "^1.8.1" @@ -8243,9 +7963,9 @@ } }, "node_modules/lilconfig": { - "version": "3.1.1", - "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.1.tgz", - "integrity": "sha512-O18pf7nyvHTckunPWCV1XUNXU1piu01y2b7ATJ0ppkUkk8ocqVWBrYjJBCwHDjD/ZWcfyrA0P4gKhzWGi5EINQ==", + "version": "3.1.2", + "resolved": "https://registry.npmjs.org/lilconfig/-/lilconfig-3.1.2.tgz", + "integrity": "sha512-eop+wDAvpItUys0FWkHIKeC9ybYrTGbU41U5K7+bttZZeohvnY7M9dZ5kB21GNWiFT2q1OoPTvncPCgSOVO5ow==", "engines": { "node": ">=14" }, @@ -8426,9 +8146,9 @@ } }, "node_modules/mdast-util-from-markdown": { - "version": "2.0.0", - "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-2.0.0.tgz", - "integrity": "sha512-n7MTOr/z+8NAX/wmhhDji8O3bRvPTV/U0oTCaZJkjhPSKTPhS3xufVhKGF8s1pJ7Ox4QgoIU7KHseh09S+9rTA==", + "version": "2.0.1", + "resolved": "https://registry.npmjs.org/mdast-util-from-markdown/-/mdast-util-from-markdown-2.0.1.tgz", + "integrity": "sha512-aJEUyzZ6TzlsX2s5B4Of7lN7EQtAxvtradMMglCQDyaTFgse6CmtmdJ15ElnVRlCg1vpNyVtbem0PWzlNieZsA==", "dependencies": { "@types/mdast": "^4.0.0", "@types/unist": "^3.0.0", @@ -8708,9 +8428,9 @@ } }, "node_modules/mdast-util-to-hast": { - "version": "13.1.0", - "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-13.1.0.tgz", - "integrity": "sha512-/e2l/6+OdGp/FB+ctrJ9Avz71AN/GRH3oi/3KAx/kMnoUsD6q0woXlDT8lLEeViVKE7oZxE7RXzvO3T8kF2/sA==", + "version": "13.2.0", + "resolved": "https://registry.npmjs.org/mdast-util-to-hast/-/mdast-util-to-hast-13.2.0.tgz", + "integrity": "sha512-QGYKEuUsYT9ykKBCMOEDLsU5JRObWQusAolFMeko/tYPufNkRffBAQjIE+99jbA87xv6FgmjLtwjh9wBWajwAA==", "dependencies": { "@types/hast": "^3.0.0", "@types/mdast": "^4.0.0", @@ -10737,9 +10457,12 @@ } }, "node_modules/object-inspect": { - "version": "1.13.1", - "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.1.tgz", - "integrity": "sha512-5qoj1RUiKOMsCCNLV1CBiPYE10sziTsnmNxkAI/rZhiD63CF7IqdFGC/XzjWjpSgLf0LxXX3bDFIh0E18f6UhQ==", + "version": "1.13.2", + "resolved": "https://registry.npmjs.org/object-inspect/-/object-inspect-1.13.2.tgz", + "integrity": "sha512-IRZSRuzJiynemAXPYtPe5BoI/RESNYR7TYm50MC5Mqbd3Jmw5y790sErYw3V6SryFJD64b74qQQs9wn5Bg/k3g==", + "engines": { + "node": ">= 0.4" + }, "funding": { "url": "https://github.com/sponsors/ljharb" } @@ -12047,9 +11770,9 @@ } }, "node_modules/react-dev-utils/node_modules/loader-utils": { - "version": "3.2.1", - "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.2.1.tgz", - "integrity": "sha512-ZvFw1KWS3GVyYBYb7qkmRM/WwL2TQQBxgCK62rlvm4WpVQ23Nb4tYjApUlfjrEGvOs7KHEsmyUn75OHZrJMWPw==", + "version": "3.3.1", + "resolved": "https://registry.npmjs.org/loader-utils/-/loader-utils-3.3.1.tgz", + "integrity": "sha512-FMJTLMXfCLMLfJxcX9PFqX5qD88Z5MRGaZCVzfuqeZSPsyiBzs+pahDQjbIWz2QIzPZz0NX9Zy4FX3lmK6YHIg==", "engines": { "node": ">= 12.13.0" } @@ -12137,20 +11860,6 @@ "resolved": "https://registry.npmjs.org/react-fast-compare/-/react-fast-compare-3.2.2.tgz", "integrity": "sha512-nsO+KSNgo1SbJqJEYRE9ERzo7YtYbou/OqjSQKxV7jcKox7+usiUVZOAC+XnDOABXggQTno0Y1CpVnuWEc1boQ==" }, - "node_modules/react-helmet": { - "version": "6.1.0", - "resolved": "https://registry.npmjs.org/react-helmet/-/react-helmet-6.1.0.tgz", - "integrity": "sha512-4uMzEY9nlDlgxr61NL3XbKRy1hEkXmKNXhjbAIOVw5vcFrsdYbH2FEwcNyWvWinl103nXgzYNlns9ca+8kFiWw==", - "dependencies": { - "object-assign": "^4.1.1", - "prop-types": "^15.7.2", - "react-fast-compare": "^3.1.1", - "react-side-effect": "^2.1.0" - }, - "peerDependencies": { - "react": ">=16.3.0" - } - }, "node_modules/react-helmet-async": { "version": "1.3.0", "resolved": "https://registry.npmjs.org/react-helmet-async/-/react-helmet-async-1.3.0.tgz", @@ -12258,14 +11967,6 @@ "react": ">=15" } }, - "node_modules/react-side-effect": { - "version": "2.1.2", - "resolved": "https://registry.npmjs.org/react-side-effect/-/react-side-effect-2.1.2.tgz", - "integrity": "sha512-PVjOcvVOyIILrYoyGEpDN3vmYNLdy1CajSFNt4TDsVQC5KpTijDvWVoR+/7Rz2xT978D8/ZtFceXxzsPwZEDvw==", - "peerDependencies": { - "react": "^16.3.0 || ^17.0.0 || ^18.0.0" - } - }, "node_modules/readable-stream": { "version": "3.6.2", "resolved": "https://registry.npmjs.org/readable-stream/-/readable-stream-3.6.2.tgz", @@ -12811,9 +12512,9 @@ "integrity": "sha512-YZo3K82SD7Riyi0E1EQPojLz7kpepnSQI9IyPbHHg1XXXevb5dJI7tpyN2ADxGcQbHG7vcyRHk0cbwqcQriUtg==" }, "node_modules/sax": { - "version": "1.3.0", - "resolved": "https://registry.npmjs.org/sax/-/sax-1.3.0.tgz", - "integrity": "sha512-0s+oAmw9zLl1V1cS9BtZN7JAd0cW5e0QH4W3LWEK6a4LaLEA2OTpGYWDY+6XasBLtz6wkm3u1xRw95mRuJ59WA==" + "version": "1.4.1", + "resolved": "https://registry.npmjs.org/sax/-/sax-1.4.1.tgz", + "integrity": "sha512-+aWOz7yVScEGoKNd4PA10LZ8sk0A/z5+nXQG5giUO5rprX9jgYsTdov9qCchZiPIZezbZH+jRut8nPodFAX4Jg==" }, "node_modules/scheduler": { "version": "0.23.2", @@ -12845,7 +12546,6 @@ "version": "2.14.0", "resolved": "https://registry.npmjs.org/search-insights/-/search-insights-2.14.0.tgz", "integrity": "sha512-OLN6MsPMCghDOqlCtsIsYgtsC0pnwVTyT9Mu6A3ewOj1DxvzZF6COrn2g86E/c05xbktB0XN04m/t1Z+n+fTGw==", - "license": "MIT", "peer": true }, "node_modules/section-matter": { @@ -13555,9 +13255,9 @@ } }, "node_modules/terser": { - "version": "5.31.0", - "resolved": "https://registry.npmjs.org/terser/-/terser-5.31.0.tgz", - "integrity": "sha512-Q1JFAoUKE5IMfI4Z/lkE/E6+SwgzO+x4tq4v1AyBLRj8VSYvRO6A/rQrPg1yud4g0En9EKI1TvFRF2tQFcoUkg==", + "version": "5.31.1", + "resolved": "https://registry.npmjs.org/terser/-/terser-5.31.1.tgz", + "integrity": "sha512-37upzU1+viGvuFtBo9NPufCb9dwM0+l9hMxYyWfBA+fbwrPqNJAhbZ6W47bBFnZHKHTUBnMvi87434qq+qnxOg==", "dependencies": { "@jridgewell/source-map": "^0.3.3", "acorn": "^8.8.2", @@ -13755,9 +13455,9 @@ } }, "node_modules/tslib": { - "version": "2.6.2", - "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.2.tgz", - "integrity": "sha512-AEYxH93jGFPn/a2iVAwW87VuUIkR1FVUKB77NwMF7nBTDkDrrT/Hpt/IrCJ0QXhW27jTBDcf5ZY7w6RiqTMw2Q==" + "version": "2.6.3", + "resolved": "https://registry.npmjs.org/tslib/-/tslib-2.6.3.tgz", + "integrity": "sha512-xNvxJEOUiWPGhUuUdQgAJPKOOJfGnIyKySOc09XkKsgdUV/3E2zvwZYdejjmRgPCgcym1juLH3226yA7sEFJKQ==" }, "node_modules/type-fest": { "version": "2.19.0", @@ -13810,10 +13510,9 @@ } }, "node_modules/typescript": { - "version": "5.4.5", - "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.4.5.tgz", - "integrity": "sha512-vcI4UpRgg81oIRUFwR0WSIHKt11nJ7SAVlYNIu+QpqeyXP+gpQJy/Z4+F0aGxSE4MqwjyXvW/TzgkLAx2AGHwQ==", - "license": "Apache-2.0", + "version": "5.5.2", + "resolved": "https://registry.npmjs.org/typescript/-/typescript-5.5.2.tgz", + "integrity": "sha512-NcRtPEOsPFFWjobJEtfihkLCZCXZt/os3zf8nTxjVH3RvTSxjrCamJpbExGvYOF+tFHc3pA65qpdwPbzjohhew==", "peer": true, "bin": { "tsc": "bin/tsc", @@ -13873,9 +13572,9 @@ } }, "node_modules/unified": { - "version": "11.0.4", - "resolved": "https://registry.npmjs.org/unified/-/unified-11.0.4.tgz", - "integrity": "sha512-apMPnyLjAX+ty4OrNap7yumyVAMlKx5IWU2wlzzUdYJO9A8f1p9m/gywF/GM2ZDFcjQPrx59Mc90KwmxsoklxQ==", + "version": "11.0.5", + "resolved": "https://registry.npmjs.org/unified/-/unified-11.0.5.tgz", + "integrity": "sha512-xKvGhPWw3k84Qjh8bI3ZeJjqnyadK+GEFtazSfZv/rKeTkTjOJho6mFqh2SM96iIcZokxiOpg78GazTSg8+KHA==", "dependencies": { "@types/unist": "^3.0.0", "bail": "^2.0.0", @@ -14330,9 +14029,9 @@ } }, "node_modules/webpack": { - "version": "5.91.0", - "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.91.0.tgz", - "integrity": "sha512-rzVwlLeBWHJbmgTC/8TvAcu5vpJNII+MelQpylD4jNERPwpBJOE2lEcko1zJX3QJeLjTTAnQxn/OJ8bjDzVQaw==", + "version": "5.92.1", + "resolved": "https://registry.npmjs.org/webpack/-/webpack-5.92.1.tgz", + "integrity": "sha512-JECQ7IwJb+7fgUFBlrJzbyu3GEuNBcdqr1LD7IbSzwkSmIevTm8PF+wej3Oxuz/JFBUZ6O1o43zsPkwm1C4TmA==", "dependencies": { "@types/eslint-scope": "^3.7.3", "@types/estree": "^1.0.5", @@ -14340,10 +14039,10 @@ "@webassemblyjs/wasm-edit": "^1.12.1", "@webassemblyjs/wasm-parser": "^1.12.1", "acorn": "^8.7.1", - "acorn-import-assertions": "^1.9.0", + "acorn-import-attributes": "^1.9.5", "browserslist": "^4.21.10", "chrome-trace-event": "^1.0.2", - "enhanced-resolve": "^5.16.0", + "enhanced-resolve": "^5.17.0", "es-module-lexer": "^1.2.1", "eslint-scope": "5.1.1", "events": "^3.2.0", @@ -14516,9 +14215,9 @@ } }, "node_modules/webpack-dev-server/node_modules/ws": { - "version": "8.17.0", - "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.0.tgz", - "integrity": "sha512-uJq6108EgZMAl20KagGkzCKfMEjxmKvZHG7Tlq0Z6nOky7YF7aq4mOx6xK8TJ/i1LeK4Qus7INktacctDgY8Ow==", + "version": "8.17.1", + "resolved": "https://registry.npmjs.org/ws/-/ws-8.17.1.tgz", + "integrity": "sha512-6XQFvXTkbfUOZOKKILFG1PDK2NDQs4azKQl26T0YS5CxqWLgXajbPZ+h4gZekJyRqFU8pvnbAbbs/3TgRPy+GQ==", "engines": { "node": ">=10.0.0" }, @@ -14760,9 +14459,9 @@ } }, "node_modules/ws": { - "version": "7.5.9", - "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.9.tgz", - "integrity": "sha512-F+P9Jil7UiSKSkppIiD94dN07AwvFixvLIj1Og1Rl9GGMuNipJnV9JzjD6XuqmAeiswGvUmNLjr5cFuXwNS77Q==", + "version": "7.5.10", + "resolved": "https://registry.npmjs.org/ws/-/ws-7.5.10.tgz", + "integrity": "sha512-+dbF1tHwZpXcbOJdVOkzLDxZP1ailvSxM6ZweXTegylPny803bFhA+vqBYw4s31NSAk4S2Qz+AKXK9a4wkdjcQ==", "engines": { "node": ">=8.3.0" }, diff --git a/package.json b/package.json index a8ca59544..78f149762 100644 --- a/package.json +++ b/package.json @@ -39,24 +39,29 @@ "write-heading-ids": "docusaurus write-heading-ids" }, "dependencies": { - "@docusaurus/core": "^3.3.2", - "@docusaurus/preset-classic": "^3.3.2", - "@docusaurus/theme-search-algolia": "^3.3.2", - "@fortawesome/fontawesome-free": "^6.5.2", - "@fortawesome/fontawesome-svg-core": "^6.5.2", - "@fortawesome/free-brands-svg-icons": "^6.5.2", - "@fortawesome/react-fontawesome": "^0.2.2", + "@docusaurus/core": "3.4.0", + "@docusaurus/preset-classic": "3.4.0", "@mdx-js/react": "^3.0.0", "clsx": "^2.0.0", - "dotenv": "^16.4.5", "prism-react-renderer": "^2.3.0", "react": "^18.0.0", - "react-dom": "^18.0.0", - "react-helmet": "^6.1.0" + "react-dom": "^18.0.0" }, "devDependencies": { - "@docusaurus/module-type-aliases": "^3.3.2", - "@docusaurus/types": "3.0.1" + "@docusaurus/module-type-aliases": "3.4.0", + "@docusaurus/types": "3.4.0" + }, + "browserslist": { + "production": [ + ">0.5%", + "not dead", + "not op_mini all" + ], + "development": [ + "last 3 chrome version", + "last 3 firefox version", + "last 5 safari version" + ] }, "engines": { "node": ">=18.0" diff --git a/sidebars.js b/sidebars.js index ea404e817..332758032 100644 --- a/sidebars.js +++ b/sidebars.js @@ -28,7 +28,6 @@ const sidebars = { }, ], */ - }; export default sidebars; diff --git a/siteConfig.js b/siteConfig.js index 05a6be5b6..0c02293ae 100644 --- a/siteConfig.js +++ b/siteConfig.js @@ -1,109 +1,110 @@ new Crawler({ - rateLimit: 8, - maxDepth: 10, - maxUrls: 5000, - startUrls: [ - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/signup", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/login", - ], - renderJavaScript: false, - sitemaps: ["https://subhadipbhowmik.github.io/30-Days-Of-CPP/sitemap.xml"], - ignoreCanonicalTo: false, - discoveryPatterns: [ - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/**", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/signup", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/login", - ], - schedule: "at 19:12 on Tuesday", - actions: [ - { - indexName: "subhadipbhowmik", - pathsToMatch: [ - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/**", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/**", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/blog/**", - ], - recordExtractor: ({ helpers }) => { - return helpers.docsearch({ - recordProps: { - lvl1: ["header h1", "article h1", "main h1", "h1", "head > title"], - content: ["article p, article li", "main p, main li", "p, li"], - lvl0: { - selectors: "", - defaultValue: "Documentation", + rateLimit: 8, + maxDepth: 10, + maxUrls: 5000, + startUrls: [ + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/signup", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/login", + ], + renderJavaScript: false, + sitemaps: ["https://subhadipbhowmik.github.io/30-Days-Of-CPP/sitemap.xml"], + ignoreCanonicalTo: false, + discoveryPatterns: [ + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/**", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/signup", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/login", + ], + schedule: "at 19:12 on Tuesday", + actions: [ + { + indexName: "subhadipbhowmik", + pathsToMatch: [ + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/**", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/**", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/blog/**", + ], + recordExtractor: ({ helpers }) => { + return helpers.docsearch({ + recordProps: { + lvl1: ["header h1", "article h1", "main h1", "h1", "head > title"], + content: ["article p, article li", "main p, main li", "p, li"], + lvl0: { + selectors: "", + defaultValue: "Documentation", + }, + lvl2: ["article h2", "main h2", "h2"], + lvl3: ["article h3", "main h3", "h3"], + lvl4: ["article h4", "main h4", "h4"], + lvl5: ["article h5", "main h5", "h5"], + lvl6: ["article h6", "main h6", "h6"], }, - lvl2: ["article h2", "main h2", "h2"], - lvl3: ["article h3", "main h3", "h3"], - lvl4: ["article h4", "main h4", "h4"], - lvl5: ["article h5", "main h5", "h5"], - lvl6: ["article h6", "main h6", "h6"], - }, - aggregateContent: true, - recordVersion: "v3", - }); + aggregateContent: true, + recordVersion: "v3", + }); + }, + }, + ], + safetyChecks: { beforeIndexPublishing: { maxLostRecordsPercentage: 30 } }, + initialIndexSettings: { + subhadipbhowmik: { + attributesForFaceting: ["type", "lang"], + attributesToRetrieve: [ + "hierarchy", + "content", + "anchor", + "url", + "url_without_anchor", + "type", + ], + attributesToHighlight: ["hierarchy", "content"], + attributesToSnippet: ["content:10"], + camelCaseAttributes: ["hierarchy", "content"], + searchableAttributes: [ + "unordered(hierarchy.lvl0)", + "unordered(hierarchy.lvl1)", + "unordered(hierarchy.lvl2)", + "unordered(hierarchy.lvl3)", + "unordered(hierarchy.lvl4)", + "unordered(hierarchy.lvl5)", + "unordered(hierarchy.lvl6)", + "content", + ], + distinct: true, + attributeForDistinct: "url", + customRanking: [ + "desc(weight.pageRank)", + "desc(weight.level)", + "asc(weight.position)", + ], + ranking: [ + "words", + "filters", + "typo", + "attribute", + "proximity", + "exact", + "custom", + ], + highlightPreTag: '<span class="algolia-docsearch-suggestion--highlight">', + highlightPostTag: "</span>", + minWordSizefor1Typo: 3, + minWordSizefor2Typos: 7, + allowTyposOnNumericTokens: false, + minProximity: 1, + ignorePlurals: true, + advancedSyntax: true, + attributeCriteriaComputedByMinProximity: true, + removeWordsIfNoResults: "allOptional", }, }, - ], - safetyChecks: { beforeIndexPublishing: { maxLostRecordsPercentage: 30 } }, - initialIndexSettings: { - subhadipbhowmik: { - attributesForFaceting: ["type", "lang"], - attributesToRetrieve: [ - "hierarchy", - "content", - "anchor", - "url", - "url_without_anchor", - "type", - ], - attributesToHighlight: ["hierarchy", "content"], - attributesToSnippet: ["content:10"], - camelCaseAttributes: ["hierarchy", "content"], - searchableAttributes: [ - "unordered(hierarchy.lvl0)", - "unordered(hierarchy.lvl1)", - "unordered(hierarchy.lvl2)", - "unordered(hierarchy.lvl3)", - "unordered(hierarchy.lvl4)", - "unordered(hierarchy.lvl5)", - "unordered(hierarchy.lvl6)", - "content", - ], - distinct: true, - attributeForDistinct: "url", - customRanking: [ - "desc(weight.pageRank)", - "desc(weight.level)", - "asc(weight.position)", - ], - ranking: [ - "words", - "filters", - "typo", - "attribute", - "proximity", - "exact", - "custom", - ], - highlightPreTag: '<span class="algolia-docsearch-suggestion--highlight">', - highlightPostTag: "</span>", - minWordSizefor1Typo: 3, - minWordSizefor2Typos: 7, - allowTyposOnNumericTokens: false, - minProximity: 1, - ignorePlurals: true, - advancedSyntax: true, - attributeCriteriaComputedByMinProximity: true, - removeWordsIfNoResults: "allOptional", - }, - }, - appId: "SKRAQTXG41", - apiKey: "4eadbd9906c2db99f8c4d53bb7202144", - indexName: "subhadipbhowmik", - extraUrls: [ - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/intro", - "https://subhadipbhowmik.github.io/30-Days-Of-CPP/blog", - ], -}); + appId: "SKRAQTXG41", + apiKey: "4eadbd9906c2db99f8c4d53bb7202144", + indexName: "subhadipbhowmik", + extraUrls: [ + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/docs/intro", + "https://subhadipbhowmik.github.io/30-Days-Of-CPP/blog", + ], + }); + \ No newline at end of file diff --git a/src/components/Callout/Callout.js b/src/components/Callout/Callout.js deleted file mode 100644 index 6324e29ee..000000000 --- a/src/components/Callout/Callout.js +++ /dev/null @@ -1,18 +0,0 @@ -// Callout.js -import React from "react"; - -const Callout = ({ type, children }) => { - const styles = { - border: "2px solid", - padding: "10px", - borderRadius: "5px", - backgroundColor: - type === "info" ? "#e2f0ff" : type === "warning" ? "#ffe5b3" : "#d9f7be", - borderColor: - type === "info" ? "#1890ff" : type === "warning" ? "#faad14" : "#52c41a", - }; - - return <div style={styles}>{children}</div>; -}; - -export default Callout; diff --git a/src/components/Chatbot/chatbot.js b/src/components/Chatbot/chatbot.js deleted file mode 100644 index 717386ce7..000000000 --- a/src/components/Chatbot/chatbot.js +++ /dev/null @@ -1,32 +0,0 @@ -import React, { useEffect } from 'react'; -import { Helmet } from 'react-helmet'; -import './style.css'; - -const Chatbot = () => { - useEffect(() => { - const script1 = document.createElement('script'); - script1.src = "https://cdn.botpress.cloud/webchat/v1/inject.js"; - script1.async = true; - document.body.appendChild(script1); - - const script2 = document.createElement('script'); - script2.src = "https://mediafiles.botpress.cloud/4e10f671-b66c-4211-a966-8d2a4b404513/webchat/config.js"; - script2.defer = true; - document.body.appendChild(script2); - - return () => { - document.body.removeChild(script1); - document.body.removeChild(script2); - }; - }, []); - - return ( - <div> - <Helmet> - <link rel="stylesheet" href="style.css" /> - </Helmet> - </div> - ); -}; - -export default Chatbot; diff --git a/src/components/Chatbot/style.css b/src/components/Chatbot/style.css deleted file mode 100644 index a4e79db33..000000000 --- a/src/components/Chatbot/style.css +++ /dev/null @@ -1,247 +0,0 @@ - -body{ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - -} - /* These CSS rules sets the text direction of the paragraph (RTL or LTR) */ - /* p, */ - .bpw-from-bot > div, - #input-message { - direction: ltr; - } - - /* This rule changes the color of the text in the input message */ - #input-message { - color: #000000; - } - - /* Changes the color of the new message indicator */ - .bpw-new-messages-indicator { - background-color: #f5f5f5; - color: #ffffff; - } - - /* Styling for the chat header container */ - .bpw-header-container { - margin: 10px; - background: #00bfa6; - border-radius: 10px; - position: relative; - overflow: hidden; - border: 1px; - border-radius: 10px; - color: #ffffff; - } - - .bpw-header-name{ - color: #ffffff; - } - - /* Styling for the typing bubble */ - .bpw-typing-bubble { - background: #000000; - } - - /* Styling for the chat bubble content */ - .bpw-chat-bubble-content { - background-color: #f5f5f5; - border-radius: 3px; - border: 1px transparent; - } - - /* Styling for the date container, header name, and header subtitle */ - .bpw-date-container, - .bpw-header-name, - .bpw-header-subtitle { - color: #ffffff; - } - - /* Styling for the layout of the chat bubble. Width, height, border, position and radius of the chat bubble */ - .bpw-layout { - width: 400px !important; - height: 70vh; - border-radius: 10px; - right: 10px; - bottom: 5px; - border: 1px; - } - /* Responsive design rules for devices with width less than or equal to 450px */ - @media(max-width:450px) { - .bpw-layout { - width: 100% !important; - height: 100%; - right: 0; - bottom: 0; - border-radius: 0; - } - } - - /* Changes the fill color of the header icons to white */ - .bpw-header-icon, - .bpw-header-icon svg, - .bpw-header-icon svg path { - fill: #ffffff !important; - } - - /* Changes the color of the placeholder text in the input message */ - #input-message::placeholder { - color: rgba(0,0,0,.30); - } - - .bpw-composer textarea{ - outline: none !important; - border: 1px solid black; - } - .bpw-composer textarea:focus{ - outline: none !important; - border: 1px solid black; - } - - /* Styling for the keyboard single choice option */ - .bpw-keyboard-single-choice { - background-color: #ffffff; - border: none; - } - - /* Styling for the buttons in the chat interface */ - .bpw-button, - .bpw-button-alt { - background-color: #00bfa6; - color: #000000; - border-radius: 10px; - border: none; - } - - - /* Styling for hover effect on the buttons in the chat interface */ - .bpw-button:hover, - .bpw-button-alt:hover { - background-color: #f5f5f5; - } - - /* Styling for the chat container, including color, scrollbar width and color, and border */ - .bpw-chat-container { - background-color: #ffffff; - scrollbar-width: thin; - scrollbar-color: #f5f5f5 #ffffff; - border: none; - } - - /* Styling for the chat bubble content when it's from the bot */ - .bpw-from-bot .bpw-chat-bubble .bpw-chat-bubble-content { - background-color: #f5f5f5; - color: #000000; - } - - /* Styling for the chat bubble content when it's from the user */ - .bpw-from-user .bpw-chat-bubble .bpw-chat-bubble-content { - background-color: #00bfa6; - color: #ffffff; - } - - /* Styling for the composer section of the chat interface */ - .bpw-composer { - background-color: #ffffff; - border-top: none; - } - - - /* Styling for the scrollbar in the chat container */ - .bpw-chat-container::-webkit-scrollbar, - .bpw-chat-container::-moz-scrollbar { - width: 10px; - background-color: #ffffff; - border: none; - } - - /* Styling for the avatar of the bot */ - .bpw-bot-avatar img, - .bpw-bot-avatar svg { - background: #000000; - border: 3px solid #ffffff; - } - - /* Styling for the general scrollbar in the web page */ - ::-webkit-scrollbar { - width: 0.5rem; - } - - /* Styling for the track of the general scrollbar and the chat container scrollbar */ - ::-webkit-scrollbar-track, - .bpw-chat-container::-webkit-scrollbar-track, - .bpw-chat-container::-moz-scrollbar-track { - background-color: transparent; - } - - /* Styling for the thumb of the general scrollbar and the chat container scrollbar */ - ::-webkit-scrollbar-thumb, - .bpw-chat-container::-webkit-scrollbar-thumb, - .bpw-chat-container::-moz-scrollbar-thumb { - background-color: #ffffff; - border-radius: 1rem; - border: 0.5rem solid transparent; - } - - /* Styling for the floating button icon in the chat interface */ - .bpw-floating-button i svg path { - fill: #00bfa6; - } - - - - /* Styling for the 'powered by' section of the chat interface */ - .bpw-powered { - text-align: center; - padding: 10px; - color: #000000; - background: #ffffff; - font-size: 14px; - border-bottom-right-radius: 10px; - border-bottom-left-radius: 10px; - } - - /* Styling for the hyperlinks in the 'powered by' section of the chat interface */ - .bpw-powered a { - color: #000000; - text-decoration: underline; - } - - /* Styling for hover effect on the hyperlinks in the 'powered by' section of the chat interface */ - .bpw-powered a:hover { - text-decoration: underline; - } - - .bpw-send-button{ - background: #00bfa6; - } - .bpw-send-button:hover{ - background-color: #000; - } - - /* Change Bot Widget Icon */ - - .bpw-widget-btn{ - border-radius: 50%; - background:#00bfa6; - } - - .bpw-floating-button::before { - background:url("data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' fill='none' viewBox='0 0 24 24' stroke-width='1.5' stroke='white' class='w-6 h-6'%3E%3Cpath stroke-linecap='round' stroke-linejoin='round' d='M8.625 12a.375.375 0 11-.75 0 .375.375 0 01.75 0zm0 0H8.25m4.125 0a.375.375 0 11-.75 0 .375.375 0 01.75 0zm0 0H12m4.125 0a.375.375 0 11-.75 0 .375.375 0 01.75 0zm0 0h-.375M21 12c0 4.556-4.03 8.25-9 8.25a9.764 9.764 0 01-2.555-.337A5.972 5.972 0 015.41 20.97a5.969 5.969 0 01-.474-.065 4.48 4.48 0 00.978-2.025c.09-.457-.133-.901-.467-1.226C3.93 16.178 3 14.189 3 12c0-4.556 4.03-8.25 9-8.25s9 3.694 9 8.25z' /%3E%3C/svg%3E"); - background-repeat: no-repeat; - background-position: center; - background-size: contain; - height:undefinedpx !important; - width:undefinedpx !important; - } - - .bpw-floating-button { - box-shadow: none !important; - } - - .bpw-floating-button:hover { - background-color: #00bfa6; - box-shadow: none !important; - } diff --git a/src/components/Contact/Contact.css b/src/components/Contact/Contact.css deleted file mode 100644 index c17c09cbc..000000000 --- a/src/components/Contact/Contact.css +++ /dev/null @@ -1,106 +0,0 @@ -/* Base styling */ -body { - font-family: 'Arial', sans-serif; - background-color: #f0f7f4; /* Light green background */ - margin: 0; - padding: 0; - } - - .contact { - text-align: center; - padding: 20px; - } - - h1 { - font-size: 2.5em; - margin-bottom: 20px; - color: #2c6e49; /* Dark green */ - } - - .contact-form { - display: inline-block; - text-align: left; - max-width: 600px; - width: 100%; - background-color: white; - padding: 30px; - border-radius: 8px; - box-shadow: 0 0 10px rgba(0, 0, 0, 0.1); - transition: transform 0.3s ease, box-shadow 0.3s ease; - } - - .contact-form:hover { - transform: translateY(-5px); - box-shadow: 0 0 20px rgba(0, 0, 0, 0.2); - } - - .form-group { - margin-bottom: 20px; - } - - .form-group label { - display: block; - margin-bottom: 5px; - font-weight: bold; - color: #00bfa6; /* Light green */ - } - - .form-group input, - .form-group textarea { - width: 100%; - padding: 10px; - border: 1px solid #ddd; - border-radius: 4px; - box-sizing: border-box; - font-size: 1em; - color: #2c6e49; /* Dark green for input text */ - transition: border-color 0.3s ease; - } - - .form-group input:focus, - .form-group textarea:focus { - border-color: #00bfa6; /* Light green */ - } - - .form-group textarea { - resize: vertical; - height: 150px; - } - - button { - display: inline-block; - padding: 10px 20px; - background-color: #00bfa6; /* Light green */ - color: white; - border: none; - border-radius: 4px; - cursor: pointer; - font-size: 1em; - transition: background-color 0.3s ease, transform 0.3s ease; - } - - button:hover { - background-color: #009e8a; /* Slightly darker light green */ - transform: translateY(-2px); - } - - /* Responsive design */ - @media (max-width: 600px) { - .contact-form { - padding: 20px; - } - - h1 { - font-size: 2em; - } - - .form-group input, - .form-group textarea { - font-size: 0.9em; - } - - button { - font-size: 0.9em; - } - } - \ No newline at end of file diff --git a/src/components/Contact/Contact.js b/src/components/Contact/Contact.js deleted file mode 100644 index cbfe465f3..000000000 --- a/src/components/Contact/Contact.js +++ /dev/null @@ -1,99 +0,0 @@ -import React, { useState } from 'react'; -import './Contact.css'; - -const Contact = () => { - const [formData, setFormData] = useState({ - name: '', - email: '', - phone: '', - subject: '', - message: '' - }); - - const handleChange = (e) => { - const { name, value } = e.target; - setFormData({ - ...formData, - [name]: value - }); - }; - - const handleSubmit = (e) => { - e.preventDefault(); - // Handle form submission logic here - console.log('Form Data Submitted:', formData); - // Optionally reset the form - setFormData({ - name: '', - email: '', - phone: '', - subject: '', - message: '' - }); - }; - - return ( - <div className="contact"> - <h1>Contact Us</h1> - <form onSubmit={handleSubmit} className="contact-form"> - <div className="form-group"> - <label htmlFor="name">Name:</label> - <input - type="text" - id="name" - name="name" - value={formData.name} - onChange={handleChange} - required - /> - </div> - <div className="form-group"> - <label htmlFor="email">Email:</label> - <input - type="email" - id="email" - name="email" - value={formData.email} - onChange={handleChange} - required - /> - </div> - <div className="form-group"> - <label htmlFor="phone">Phone:</label> - <input - type="tel" - id="phone" - name="phone" - value={formData.phone} - onChange={handleChange} - required - /> - </div> - <div className="form-group"> - <label htmlFor="subject">Subject:</label> - <input - type="text" - id="subject" - name="subject" - value={formData.subject} - onChange={handleChange} - required - /> - </div> - <div className="form-group"> - <label htmlFor="message">Message:</label> - <textarea - id="message" - name="message" - value={formData.message} - onChange={handleChange} - required - /> - </div> - <button type="submit">Submit</button> - </form> - </div> - ); -}; - -export default Contact; diff --git a/src/components/DailyTips/DailyTips.css b/src/components/DailyTips/DailyTips.css deleted file mode 100644 index 5d22a8b04..000000000 --- a/src/components/DailyTips/DailyTips.css +++ /dev/null @@ -1,53 +0,0 @@ -.daily-tip { - background-color: #fff3cd; - border: 1px solid #ffeeba; - padding: 20px; - margin: 20px 0; - text-align: center; - box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); - border-radius: 8px; - transition: background-color 0.3s ease, transform 0.3s ease; - font-family: 'Arial', sans-serif; - color: #856404; - position: relative; -} - -.daily-tip:hover { - background-color: #ffeeba; - transform: scale(1.02); -} - -.daily-tip h3 { - margin-bottom: 10px; - font-size: 1.5rem; - color: #856404; -} - -.daily-tip p { - font-size: 1.2rem; - margin-bottom: 15px; -} - -.new-tip-button { - padding: 10px 20px; - background-color: #007bff; - color: white; - border: none; - cursor: pointer; - border-radius: 4px; - transition: background-color 0.3s ease; -} - -.new-tip-button:hover { - background-color: #0056b3; -} - -.fade-in { - animation: fadeIn 1s ease-in-out; -} - -@keyframes fadeIn { - from { opacity: 0; } - to { opacity: 1; } -} - \ No newline at end of file diff --git a/src/components/DailyTips/DailyTips.js b/src/components/DailyTips/DailyTips.js deleted file mode 100644 index 8058cda7f..000000000 --- a/src/components/DailyTips/DailyTips.js +++ /dev/null @@ -1,39 +0,0 @@ -import React, { useState, useEffect } from 'react'; -import tips from '../../data/dailyTips.json'; -import './DailyTips.css'; - -const DailyTips = () => { - const [tip, setTip] = useState(''); - const [fadeClass, setFadeClass] = useState(''); - - useEffect(() => { - const getRandomTip = () => { - return tips[Math.floor(Math.random() * tips.length)]; - }; - - const randomTip = getRandomTip(); - setTip(randomTip); - setFadeClass('fade-in'); - - const interval = setInterval(() => { - setFadeClass('fade-out'); - setTimeout(() => { - setTip(getRandomTip()); - setFadeClass('fade-in'); - }, 500); - }, 10000); - - return () => clearInterval(interval); - }, []); - - return ( - <div className={`daily-tip ${fadeClass}`}> - <h3>Daily Tip</h3> - <p>{tip}</p> - </div> - ); -}; - -export default DailyTips; - - diff --git a/src/components/HomepageFeatures/index.js b/src/components/HomepageFeatures/index.js index dc95b7370..faf32b581 100644 --- a/src/components/HomepageFeatures/index.js +++ b/src/components/HomepageFeatures/index.js @@ -1,8 +1,6 @@ -import React from 'react'; import clsx from 'clsx'; import Heading from '@theme/Heading'; import styles from './styles.module.css'; -import ScrollToTopButton from '../ScrollToTop/ScrollToTopButton'; const FeatureList = [ { @@ -10,8 +8,7 @@ const FeatureList = [ Svg: require('@site/static/img/hero_images/structured_curriculum.svg').default, description: ( <> - Clear 30-day plan, daily lessons covering essential C++ concepts in an - organized, progressive manner. + Clear 30-day plan, daily lessons covering essential C++ concepts in an organized, progressive manner. </> ), }, @@ -20,8 +17,7 @@ const FeatureList = [ Svg: require('@site/static/img/hero_images/well_documentation.svg').default, description: ( <> - Detailed guides with explanations, code samples, and resources aiding - better understanding of <code>C++</code> topics. + Detailed guides with explanations, code samples, and resources aiding better understanding of <code>C++</code> topics. </> ), }, @@ -60,24 +56,22 @@ const FeatureList = [ Svg: require('@site/static/img/hero_images/community_engagement.svg').default, description: ( <> - Supportive community fostering interaction, collaboration & learning - through discussions & shared experiences among participants. + Accessible collaborative C++ project, providing hands-on experience and + opportunities for practical learning and contributions. </> ), }, ]; -function Feature({ Svg, title, description }) { +function Feature({Svg, title, description}) { return ( - <div className={clsx("col col--4")}> - <div className={styles.featureContainer}> - <div className="text--center"> - <Svg className={styles.featureSvg} role="img" /> - </div> - <div className="text--center padding-horiz--md"> - <Heading as="h4" className={styles.heading}>{title}</Heading> - <p>{description}</p> - </div> + <div className={clsx('col col--4')}> + <div className="text--center"> + <Svg className={styles.featureSvg} role="img" /> + </div> + <div className="text--center padding-horiz--md"> + <Heading as="h3">{title}</Heading> + <p>{description}</p> </div> </div> ); @@ -92,7 +86,6 @@ export default function HomepageFeatures() { <Feature key={idx} {...props} /> ))} </div> - <ScrollToTopButton /> </div> </section> ); diff --git a/src/components/HomepageFeatures/styles.module.css b/src/components/HomepageFeatures/styles.module.css index ffecb2c5e..b248eb2e5 100644 --- a/src/components/HomepageFeatures/styles.module.css +++ b/src/components/HomepageFeatures/styles.module.css @@ -1,55 +1,11 @@ -body{ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - .features { display: flex; - flex-wrap: wrap; - justify-content: center; - padding: 4rem 0; -} - -.featureContainer { - padding: 1rem; - border: 3px solid black; - box-shadow: 0 4px 8px rgba(0, 0, 0, 0.1); - border-radius: 8px; - background-color: var(--ifm-font-color-base-inverse); - margin: 1rem; - transition: box-shadow 0.3s ease; - min-height: 410px; - height: auto; - display: flex; - flex-direction: column; - justify-content: center; align-items: center; - word-wrap: break-word; -} - -.featureContainer:hover { - box-shadow: 0 8px 20px var(--ifm-font-color-base); - transform: translateY(-10px); - background-color: rgb(105, 225, 213); - transition: background-color 500ms ease; + padding: 2rem 0; + width: 100%; } .featureSvg { height: 200px; width: 200px; } - -.textCenter { - text-align: center; -} - -.paddingHorizMd { - padding: 0 0.5rem; -} - -.heading { - margin-top: 0; - font-size: 1.2rem; -} diff --git a/src/components/ScrollToTop/ScrollToTopButton.js b/src/components/ScrollToTop/ScrollToTopButton.js deleted file mode 100644 index e322e7fcb..000000000 --- a/src/components/ScrollToTop/ScrollToTopButton.js +++ /dev/null @@ -1,40 +0,0 @@ -import React, { useState, useEffect } from 'react'; -import styles from './ScrollToTopButton.module.css'; - -const ScrollToTop = () => { - const [isVisible, setIsVisible] = useState(false); - - const toggleVisibility = () => { - if (window.scrollY > 300) { - setIsVisible(true); - } else { - setIsVisible(false); - } - }; - - const scrollToTop = () => { - window.scrollTo({ - top: 0, - behavior: 'smooth', - }); - }; - - useEffect(() => { - window.addEventListener('scroll', toggleVisibility); - return () => { - window.removeEventListener('scroll', toggleVisibility); - }; - }, []); - - return ( - <div className={styles.scrollToTop}> - {isVisible && ( - <button onClick={scrollToTop} className={styles.button}> - ↑ - </button> - )} - </div> - ); -}; - -export default ScrollToTop; diff --git a/src/components/ScrollToTop/ScrollToTopButton.module.css b/src/components/ScrollToTop/ScrollToTopButton.module.css deleted file mode 100644 index 7f95bced7..000000000 --- a/src/components/ScrollToTop/ScrollToTopButton.module.css +++ /dev/null @@ -1,25 +0,0 @@ -.scrollToTop { - position: fixed; - - bottom: 48px; - left : 32px; - z-index: 1000; -} - -.button { - background-color: #1ABC9C; - border: none; - color: white; - padding: 10px 15px; - height: 45px; - width: 45px; - border-radius: 50%; - cursor: pointer; - font-size: 24px; - box-shadow: 0px 4px 6px rgba(0, 0, 0, 0.1); - transition: background-color 0.3s ease; -} - -.button:hover { - background-color: #148F77; -} diff --git a/src/components/Toast/Toast.js b/src/components/Toast/Toast.js deleted file mode 100644 index 1b129a889..000000000 --- a/src/components/Toast/Toast.js +++ /dev/null @@ -1,28 +0,0 @@ -import React, { useState } from "react"; -import "./toastStyles.css"; // Import CSS file for styling - -const ToastMessage = () => { - const [showToast, setShowToast] = useState(false); - - const toggleToast = () => { - setShowToast(!showToast); - // Automatically hide the toast after 3 seconds (3000 milliseconds) - setTimeout(() => { - setShowToast(false); - }, 3000); - }; - - return ( - <div> - <button onClick={toggleToast}>Show Toast</button> - - {showToast && ( - <div className="toast"> - <span className="toast-text">This is a toast message!</span> - </div> - )} - </div> - ); -}; - -export default ToastMessage; diff --git a/src/components/Toast/toastStyles.css b/src/components/Toast/toastStyles.css deleted file mode 100644 index d7ede84ea..000000000 --- a/src/components/Toast/toastStyles.css +++ /dev/null @@ -1,25 +0,0 @@ -body{ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - -} - -/* toastStyles.css */ - -.toast { - position: fixed; - bottom: 20px; - left: 50%; - transform: translateX(-50%); - background-color: #333; - color: #fff; - padding: 10px 20px; - border-radius: 5px; - z-index: 9999; -} - -.toast-text { - font-size: 16px; -} diff --git a/src/css/custom.css b/src/css/custom.css index 1b6c76fdc..69a59f50e 100644 --- a/src/css/custom.css +++ b/src/css/custom.css @@ -1,5 +1,10 @@ -@import url("~@fortawesome/fontawesome-free/css/all.min.css"); +/** + * Any CSS included here will be global. The classic template + * bundles Infima by default. Infima is a CSS framework designed to + * work well for content-centric websites. + */ +/* You can override the default Infima variables here. */ :root { --ifm-color-primary: #00bfa6; --ifm-color-primary-dark: #29784c; @@ -25,21 +30,7 @@ --ifm-font-color-base-inverse-dark: rgb(29, 43, 52); /* dark mode color */ } -body { - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; - background-color: var(--background-color-light); - color: var(--text-color-light); - font-family: Arial, sans-serif; - line-height: 1.6; -} - -[data-theme="light"] { - --ifm-font-color-base-inverse: var(--ifm-font-color-base-inverse-light); -} - +/* For readability concerns, you should choose a lighter palette in dark mode. */ [data-theme="dark"] { --ifm-color-primary: #25c2a0; --ifm-color-primary-dark: #21af90; @@ -62,303 +53,3 @@ body { --box-shadow-hover: 0 6px 10px rgba(0, 0, 0, 0.25); --footer-link-hover-bg: linear-gradient(90deg, #21af90, #25c2a0); } -::-webkit-scrollbar-track -{ - -webkit-box-shadow: inset 0 0 6px rgba(0,0,0,0.3); - background-color: #F5F5F5; -} - -::-webkit-scrollbar -{ - width: 10px; - background-color: #F5F5F5; -} - -::-webkit-scrollbar-thumb -{ - background-color: #0ae; - - background-image: -webkit-gradient(linear, 0 0, 0 100%, - color-stop(.5, rgba(255, 255, 255, .2)), - color-stop(.5, transparent), to(transparent)); -} -.footer { - text-align: center; - padding: 20px; - background-color: rgb(29, 43, 52); - color: var(--text-color-dark); - transition: background-color 0.3s, color 0.3s; -} - -.footer a { - color: var(--ifm-color-primary); - text-decoration: none; - transition: color 0.3s, background-position 0.3s; - background: linear-gradient(to right, var(--ifm-color-primary) 50%, var(--footer-link-hover-bg) 50%); - background-size: 200% 100%; - background-position: right bottom; -} - -.footer a:hover { - color: var(--ifm-color-primary-lightest); - background-position: left bottom; -} - -.footer .col { - padding: 10px; - transition: transform 0.3s, box-shadow 0.3s; -} - -.footer .col:hover { - transform: translateY(-5px); - box-shadow: var(--box-shadow-hover); -} - -@media (min-width: 700px) { - .footer .col { - display: inline-block; - width: 30%; - margin: 1.66%; - } -} - -/* Additional hover effects for items */ -.footer .col a { - display: inline-block; - padding: 5px 0; - transition: transform 0.3s, color 0.3s, background-position 0.3s; -} - -.footer .col a:hover { - transform: scale(1.1); - color: var(--ifm-color-primary-lightest); -} - -/* Optional: Add a subtle animation on page load */ -@keyframes fadeIn { - from { - opacity: 0; - } - to { - opacity: 1; - } -} - -.footer { - animation: fadeIn 1s ease-in-out; -} - -.footer a::after { - content: ""; - display: block; - width: 0; - height: 2px; - background: var(--ifm-color-primary-lightest); - transition: width 0.3s; -} - -.footer a:hover::after { - width: 100%; -} -.footer a{ - text-decoration: none; -} -p.text-color { - background-color: #f5f7f9; - color: #090909; - padding: 10px; - border-radius: 5px; -} - -h1.center { - text-align: center; -} - -.form-container { - max-width: 400px; - margin: 50px auto; - padding: 20px; - background: var(--background-color-light); - border-radius: 10px; - box-shadow: var(--box-shadow); - transition: box-shadow 0.3s ease; - background-color: var(--ifm-font-color-base-inverse); -} - -.form-container:hover { - box-shadow: var(--box-shadow-hover); -} - -.form-container h1 { - text-align: center; - margin-bottom: 20px; - color: var(--text-color-light); -} - -.form-container form { - margin-top: 20px; -} - -.form-container input[type="text"], -.form-container input[type="email"], -.form-container input[type="password"], -.form-container button { - width: 100%; - padding: 12px; - margin-bottom: 15px; - border: 1px solid var(--input-border); - border-radius: 5px; - box-sizing: border-box; - font-size: 16px; - transition: all 0.3s ease; -} - -.form-container input[type="text"], -.form-container input[type="email"], -.form-container input[type="password"] { - background: var(--input-background); - color: var(--text-color-light); -} - -.form-container input[type="text"]:focus, -.form-container input[type="email"]:focus, -.form-container input[type="password"]:focus { - outline: none; - border-color: var(--input-focus-border); - box-shadow: 0 0 5px var(--input-focus-border); -} - -.form-container btn { - background: linear-gradient(45deg, #4caf50, #2e8b57); - color: #f9f9f9; - cursor: pointer; - transition: all 0.3s ease; - width: 500px; - border-radius: 3px; - padding: 5px; -} - -.form-container btn:hover { - background: linear-gradient(45deg, #2e8b57, #4caf50); -} - -.form-container button { - background: var(--button-background); - color: #f9f9f9; - cursor: pointer; - border: none; -} - -.form-container button:hover { - background: var(--button-hover-background); -} - -.form-container p { - color: #090909; - margin-top: 20px; - text-align: center; -} - -.form-container a { - color: #007bff; - text-decoration: none; -} - -.form-container a:hover { - text-decoration: underline; -} - -/* Basic styles for the body */ -body { - font-family: Arial, sans-serif; - margin: 0; - padding: 20px; - height: 200vh; /* Set height to make scrollbar visible */ - /* Additional styling as needed */ -} - -/* Custom scrollbar styles for the entire page */ -html, -body { - scrollbar-width: thin; /* For Firefox */ - scrollbar-color: linear-gradient(180deg, #ff7f50, #ff6347) #f1f1f1; /* For Firefox */ -} - -/* Webkit-based browsers (Chrome, Safari) */ -html::-webkit-scrollbar, -body::-webkit-scrollbar { - width: 12px; /* Width of the entire scrollbar */ -} - -html::-webkit-scrollbar-track, -body::-webkit-scrollbar-track { - background: #f1f1f1; /* Color of the track */ -} - -html::-webkit-scrollbar-thumb, -body::-webkit-scrollbar-thumb { - background: linear-gradient( - 180deg, - #ff7f50, - #ff6347 - ); /* Linear gradient color for the thumb */ - border-radius: 6px; /* Rounded corners for the thumb */ -} - -html::-webkit-scrollbar-thumb:hover, -body::-webkit-scrollbar-thumb:hover { - background: linear-gradient( - 180deg, - #ff6347, - #ff4500 - ); /* Darker gradient on hover */ -} - -.navbar__link[href*="https://github.com/subhadipbhowmik/30-Days-Of-CPP/"]::before -{ - content: "\f09b"; /* GitHub icon */ - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} - -.footer__link-item[href*="https://www.facebook.com/"]::before -{ - content: "\f09a"; /* Facebook icon */ - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} - -.footer__link-item[href*="https://twitter.com/"]::before -{ - content: "\f099"; /* Twitter icon */ - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} - -.footer__link-item[href*="https://discord.com/"]::before -{ - content: "\f392"; /* Discord icon */ - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} - -.footer__link-item[href*="https://www.linkedin.com/"]::before -{ - content: "\f08c"; /* LinkedIn icon */ - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} - -.footer__link-item[href*="https://github.com/"]::before -{ - content: "\f09b"; - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} - -.footer__link-item[href*="https://github.com/subhadipbhowmik/30-Days-Of-CPP/"]::before -{ - content: "\f09b"; /* GitHub icon */ - font-family: "Font Awesome 5 Brands"; - margin-right: 0.5em; -} diff --git a/src/data/dailyTips.json b/src/data/dailyTips.json deleted file mode 100644 index d5ef05eff..000000000 --- a/src/data/dailyTips.json +++ /dev/null @@ -1,31 +0,0 @@ -[ - "Tip: Use 'const' whenever possible to avoid accidental changes.", - "Tip: Prefer using 'auto' for type inference to make code cleaner.", - "Tip: Don’t confuse assign (=) with test-for-equality (==).", - "Tip: Remember: semi’s after class declarations, not functions.", - "Tip: Break problems down: When faced with a complex problem, break it down into smaller, more manageable parts. Solve each part individually before combining them into a solution.", - "Tip: Use RAII (Resource Acquisition Is Initialization) to manage resources and avoid memory leaks.", - "Tip: Practice using the Standard Template Library (STL) to simplify common tasks.", - "Tip: Learn and understand the differences between pointers and references.", - "Tip: Always initialize variables to avoid undefined behavior.", - "Tip: Use smart pointers (std::unique_ptr, std::shared_ptr) to manage dynamic memory safely.", - "Tip: Avoid using raw pointers unless absolutely necessary.", - "Tip: Familiarize yourself with common design patterns and their implementation in C++.", - "Tip: Use range-based for loops for cleaner and more readable code.", - "Tip: Use assert statements to catch logical errors during development.", - "Tip: Keep your code modular by breaking it into small, reusable functions.", - "Tip: Document your code to make it easier for others (and yourself) to understand.", - "Tip: Learn how to use a debugger to step through your code and identify issues.", - "Tip: Regularly refactor your code to improve its structure and readability.", - "Tip: Use version control (e.g., Git) to track changes and collaborate with others.", - "Tip: Keep your functions short and focused on a single task.", - "Tip: Use namespaces to avoid name collisions in larger projects.", - "Tip: Understand and use different levels of access control (public, protected, private).", - "Tip: Use inline functions for small, frequently used functions to improve performance.", - "Tip: Prefer std::vector over raw arrays for dynamic storage.", - "Tip: Avoid global variables to reduce dependencies and improve code maintainability.", - "Tip: Use exception handling to manage errors gracefully.", - "Tip: Learn about multithreading and how to use it effectively in C++.", - "Tip: Profile your code to identify and optimize performance bottlenecks.", - "Tip: Keep learning and experimenting with new C++ features and libraries." -] diff --git a/src/pages/index.js b/src/pages/index.js index ea1bd99aa..13fb46023 100644 --- a/src/pages/index.js +++ b/src/pages/index.js @@ -1,119 +1,43 @@ -import clsx from "clsx"; -import Link from "@docusaurus/Link"; -import React, { useEffect } from 'react'; +import clsx from 'clsx'; +import Link from '@docusaurus/Link'; +import useDocusaurusContext from '@docusaurus/useDocusaurusContext'; +import Layout from '@theme/Layout'; +import HomepageFeatures from '@site/src/components/HomepageFeatures'; -import useDocusaurusContext from "@docusaurus/useDocusaurusContext"; -import Layout from "@theme/Layout"; -import HomepageFeatures from "@site/src/components/HomepageFeatures"; -import Chatbot from "../components/Chatbot/chatbot"; -import Heading from "@theme/Heading"; -import styles from "./index.module.css"; -import DailyTips from "../components/DailyTips/DailyTips"; -import Contact from "../components/Contact/Contact"; +import Heading from '@theme/Heading'; +import styles from './index.module.css'; function HomepageHeader() { - const { siteConfig } = useDocusaurusContext(); + const {siteConfig} = useDocusaurusContext(); return ( - <header className={clsx("hero hero--primary", styles.heroBanner)}> + <header className={clsx('hero hero--primary', styles.heroBanner)}> <div className="container"> - <Heading as="h1" className={clsx("hero__title", styles.main_title)}> + <Heading as="h1" className="hero__title"> {siteConfig.title} </Heading> - <p className={clsx("hero__subtitle", styles.sub_title)}>{siteConfig.tagline}</p> - <p className={clsx("hero__subtitle", styles.sub_title)}> - {siteConfig.tagline} - </p> + <p className="hero__subtitle">{siteConfig.tagline}</p> <div className={styles.buttons}> <Link className="button button--secondary button--lg" - to="/docs/category/day-01" - > - Start your Challenge Today⏱️ + to="/docs/intro"> + Start Your Challenge Today </Link> </div> </div> - <div className="snowflakes" aria-hidden="true" id="snowflakesContainer"> - {/* Snowflakes will be dynamically created here */} - <div className="snowflakes" aria-hidden="true"> - <div className="snowflake">❅</div> - <div className="snowflake">❆</div> - <div className="snowflake">❄</div> - </div> </header> ); } -const Home = () => { - const { siteConfig } = useDocusaurusContext(); - - useEffect(() => { - - const snowflakesContainer = document.getElementById('snowflakesContainer'); - - function createSnowflake() { - const snowflake = document.createElement('div'); - snowflake.className = 'snowflake'; - - snowflake.textContent = ['❅', '❆', '❄'][Math.floor(Math.random() * 3)]; - snowflake.style.left = Math.random() * 100 + 'vw'; - snowflake.style.animationDuration = Math.random() * 3 + 2 + 's'; // between 2 and 5 seconds - snowflake.style.fontSize = Math.random() * 1 + 1 + 'em'; // between 1em and 2em - snowflake.style.opacity = Math.random(); - - snowflakesContainer.appendChild(snowflake); - - setTimeout(() => { - snowflake.remove(); - }, 5000); // remove snowflake after 5 seconds - } - - const interval = setInterval(createSnowflake, 200); - - return () => clearInterval(interval); // Cleanup function to stop interval on component unmount - - }, []); - +export default function Home() { + const {siteConfig} = useDocusaurusContext(); return ( <Layout - title="Home" - description="30 days of CPP programming challenge is a step-by-step guide to learn CPP programming language in 30 days. Master the fundamental concepts of CPP Programming easily." - > + title={`Hello from ${siteConfig.title}`} + description="Description will go into a meta tag in <head />"> <HomepageHeader /> - <main style={{ position: 'relative' }}> - <DailyTips /> + <main> <HomepageFeatures /> - <Chatbot /> - <div id="contact"> - <Contact /> - </div> </main> </Layout> ); -}; - -export default Home; } - - - document.addEventListener('DOMContentLoaded', () => { - const snowflakesContainer = document.querySelector('.snowflakes'); - - function createSnowflake() { - const snowflake = document.createElement('div'); - snowflake.classList.add('snowflake'); - snowflake.textContent = ['❅', '❆', '❄'][Math.floor(Math.random() * 3)]; - snowflake.style.left = Math.random() * 100 + 'vw'; - snowflake.style.animationDuration = Math.random() * 3 + 2 + 's'; // between 2 and 5 seconds - snowflake.style.fontSize = Math.random() * 1 + 1 + 'em'; // between 1em and 2em - snowflake.style.opacity = Math.random(); - - snowflakesContainer.appendChild(snowflake); - - setTimeout(() => { - snowflake.remove(); - }, 5000); // remove snowflake after 5 seconds - } - - setInterval(createSnowflake, 200); -}); - diff --git a/src/pages/index.module.css b/src/pages/index.module.css index e1257e2bb..9f71a5da7 100644 --- a/src/pages/index.module.css +++ b/src/pages/index.module.css @@ -3,86 +3,21 @@ * and scoped locally. */ -body{ - -webkit-user-select: none; - -moz-user-select: none; - -ms-user-select: none; - user-select: none; -} - .heroBanner { padding: 4rem 0; text-align: center; position: relative; overflow: hidden; - height: 35rem; -} -.main_title{ - font-size: 6rem; - font-weight: 700; - margin-bottom: 1rem; - background: linear-gradient(45deg, #240750, #01204E); - -webkit-background-clip: text; - -webkit-text-fill-color: transparent; -} - -.sub_title{ - margin: 0 auto; - font-size: 1.5rem; - font-weight: 400; - margin-bottom: 1rem; - width: 50%; - } @media screen and (max-width: 996px) { .heroBanner { padding: 2rem; } - .main_title{ - font-size: 2.5rem; - } - .sub_title{ - font-size: 1.2rem; - width: 80%; - } } .buttons { - margin-top: 2rem; display: flex; align-items: center; justify-content: center; } - -.snowflakes { - position: fixed; - top: 0; - left: 0; - width: 100%; - height: 100%; - pointer-events: none; -} - -.snowflake { - position: absolute; - top: -10px; - z-index: 9999; - user-select: none; - pointer-events: none; - color: white; - font-size: 1em; - will-change: transform; - animation: fall linear infinite; -} - -@keyframes fall { - 0% { - transform: translateY(-100vh) rotate(0deg); - opacity: 1; - } - 100% { - transform: translateY(100vh) rotate(360deg); - opacity: 0; - } -} \ No newline at end of file diff --git a/src/pages/login.js b/src/pages/login.js deleted file mode 100644 index 5873cbdc9..000000000 --- a/src/pages/login.js +++ /dev/null @@ -1,103 +0,0 @@ -import Link from '@docusaurus/Link'; -import React, { useState } from 'react'; -<link rel="stylesheet" type="text/css" href="/css/custom.css"></link> - -import clsx from "clsx"; -import useDocusaurusContext from "@docusaurus/useDocusaurusContext"; -import Layout from "@theme/Layout"; -import Chatbot from "../components/Chatbot/chatbot"; -import Heading from "@theme/Heading"; -import styles from "./index.module.css"; - - -function HomepageHeader() { - const { siteConfig } = useDocusaurusContext(); - return ( - <header className={clsx("hero hero--primary")} style={{ display:'none' }}> - <div className="container"> - <Heading as="h1" className={clsx("hero__title")}> - </Heading> - </div> - </header> - ); -} - -function App() { - - const [passwordShown, setPasswordShown] = useState(false); - const [email, setEmail] = useState(''); - const [password, setPassword] = useState(''); - const togglePasswordVisibility = () => { - setPasswordShown(!passwordShown); - }; - const handleSubmit = async (event) => { - event.preventDefault(); - - try { - const response = await fetch('http://localhost:5000/api/login', { - method: 'POST', - headers: { - 'Content-Type': 'application/json' - }, - body: JSON.stringify({ email, password }) - }); - - const data = await response.json(); - - if (response.ok) { - localStorage.setItem('token', data.token); - window.location.href = '/30-Days-Of-CPP/'; - } else { - alert(data.message); - } - } catch (error) { - console.error('Error:', error); - alert('An error occurred. Please try again.'); - } - }; - - - return ( - <> - <Layout - title="Home" - description="30 days of CPP programming challenge is a step-by-step guide to learn CPP programming language in 30 days. Master the fundamental concepts of CPP Programming easily." - > - <HomepageHeader /> - <main style={{ position: 'relative' }}> - <div className="form-container"> - <h2>Login</h2> - <form onSubmit={handleSubmit}> - <div className="input-container"> - <label htmlFor="email">Email:</label> - <input type="text" id="username" name="username" required onChange={(e) => setEmail(e.target.value)} /> - </div> - <div className="input-container"> - <label htmlFor="password">Password:</label> - <input - type={passwordShown ? 'text' : 'password'} - id="password" - name="password" - onChange={(e) => setPassword(e.target.value)} - required - ></input> - <span><btn className="toggle-password" onClick={togglePasswordVisibility}> - {passwordShown ? 'Hide' : 'Show'} - </btn> - </span> - </div> - - <div className="input-container"> - <button type="submit">Login</button> - <p className='text-color'>Don't have an account yet? <Link to ="signup"> Sign Up</Link></p> - </div> - </form> - </div> - <Chatbot /> - </main> - </Layout> - </> - ); -} - -export default App; diff --git a/src/pages/login.md b/src/pages/login.md deleted file mode 100644 index b034f6338..000000000 --- a/src/pages/login.md +++ /dev/null @@ -1,19 +0,0 @@ ---- -id: login -title: Login ---- - -<h1 class="center">Login</h1> - -<link rel="stylesheet" type="text/css" href="/css/custom.css"></link> - - -<div class="form-container"> - <form> - <input type="email" name="email" placeholder="Email" required></input> - <input type="password" name="password" placeholder="Password" required></input> - <button type="submit">Log In</button> - </form> - <p class="text-color">Don't have an account yet? [Sign Up](signup)tttt</p> -</div> - diff --git a/src/pages/markdown-page.md b/src/pages/markdown-page.md new file mode 100644 index 000000000..9756c5b66 --- /dev/null +++ b/src/pages/markdown-page.md @@ -0,0 +1,7 @@ +--- +title: Markdown page example +--- + +# Markdown page example + +You don't need React to write simple standalone pages. diff --git a/src/pages/signup.js b/src/pages/signup.js deleted file mode 100644 index 4d4031482..000000000 --- a/src/pages/signup.js +++ /dev/null @@ -1,119 +0,0 @@ -import React, { useState, useEffect } from "react"; -import Link from '@docusaurus/Link'; -import Layout from "@theme/Layout"; -import Heading from "@theme/Heading"; -import useDocusaurusContext from "@docusaurus/useDocusaurusContext"; -import clsx from "clsx"; -function HomepageHeader() { - const { siteConfig } = useDocusaurusContext(); - return ( - <header className={clsx("hero hero--primary")} style={{ display: 'none' }}> - <div className="container"> - <Heading as="h1" className={clsx("hero__title")}> - </Heading> - </div> - </header> - ); -} -const SignUp = () => { - const [passwordShown, setPasswordShown] = useState(false); - - const togglePasswordVisibility = () => { - setPasswordShown(!passwordShown); - }; - - useEffect(() => { - const form = document.getElementById("signupForm"); - form.addEventListener("submit", async function (event) { - event.preventDefault(); - - const username = event.target.username.value; - const email = event.target.email.value; - const password = event.target.password.value; - - try { - const response = await fetch("http://localhost:5000/api/signup", { - method: "POST", - headers: { - "Content-Type": "application/json", - }, - body: JSON.stringify({ username, email, password }), - }); - - const data = await response.json(); - - if (response.ok) { - localStorage.setItem("token", data.token); - window.location.href = "/30-Days-Of-CPP/"; - } else { - alert(data.message); - } - } catch (error) { - console.error("Error:", error); - alert("An error occurred. Please try again."); - } - }); - }, []); - - return ( - <div> - <Layout - title="Home" - description="30 days of CPP programming challenge is a step-by-step guide to learn CPP programming language in 30 days. Master the fundamental concepts of CPP Programming easily." - > - <HomepageHeader /> - <h1 className="center">Sign Up</h1> - <link rel="stylesheet" type="text/css" href="/css/custom.css" /> {/* Move this to index.html or App.js */} - <div className="form-container"> - <form id="signupForm"> - <div className="input-container"> - <label htmlFor="Username">Username:</label> - <input - type="text" - id="username" - name="username" - placeholder="Username" - required - /> - </div> - <div className="input-container"> - <label htmlFor="email">Email:</label> - <input - type="email" - id="email" - name="email" - placeholder="Email" - required - /> - </div> - <div className="input-container"> - <label htmlFor="password">Password:</label> - <input - type={passwordShown ? "text" : "password"} - id="password" - name="password" - placeholder="Password" - required - /> - <span> - <button - className="toggle-password" - onClick={togglePasswordVisibility} - type="button" // Specify type="button" for toggle button - > - {passwordShown ? "Hide" : "Show"} - </button> - </span> - </div> - <button type="submit">Sign Up</button> - </form> - <p className="text-color"> - Already have an account? <a href="/30-Days-Of-CPP/login">Log In</a> - </p> - </div> - </Layout> - </div> - ); -}; - -export default SignUp; diff --git a/src/pages/signup.md b/src/pages/signup.md deleted file mode 100644 index 5a4c70770..000000000 --- a/src/pages/signup.md +++ /dev/null @@ -1,20 +0,0 @@ ---- -id: signup -title: Sign Up ---- - -<h1 class="center">Sign Up</h1> - -<link rel="stylesheet" type="text/css" href="/css/custom.css"></link> - -<div class="form-container"> - <form> - <input type="text" name="username" placeholder="Username" required></input> - <input type="email" name="email" placeholder="Email" required></input> - <input type="password" name="password" placeholder="Password" required></input> - <button type="submit">Sign Up</button> - </form> - <p class="text-color">Already have an account? [Log In](login)</p> -</div> - - diff --git a/src/pages/test.js b/src/pages/test.js deleted file mode 100644 index fcac9eafb..000000000 --- a/src/pages/test.js +++ /dev/null @@ -1,22 +0,0 @@ -import React from 'react'; -import Layout from '@theme/Layout'; - -export default function Hello() { - return ( - <Layout title="Hello" description="Hello React Page"> - <div - style={{ - display: 'flex', - justifyContent: 'center', - alignItems: 'center', - height: '50vh', - fontSize: '20px', - }}> - <p> - Hello, World! This is a test page. You can find the file at{' '} - <code>src/pages/test.js</code>. - </p> - </div> - </Layout> - ); -} \ No newline at end of file diff --git a/static/img/docusaurus-social-card.jpg b/static/img/docusaurus-social-card.jpg deleted file mode 100644 index ffcb44821..000000000 Binary files a/static/img/docusaurus-social-card.jpg and /dev/null differ diff --git a/static/img/docusaurus.png b/static/img/docusaurus.png deleted file mode 100644 index f458149e3..000000000 Binary files a/static/img/docusaurus.png and /dev/null differ