面試題:實現學生管理系統

? ? ? ? 這是我在以前面試中遇到的一個問題,?面試官說:你能現場實現一個學生管理系統嗎,實現對學生的增刪查改這4個功能

? ? ? ? 當時寫了半天沒寫出來.....,所以我在這里記錄一下

10分鐘實現學生管理系統并實現 增刪查改 功能

#include <iostream>
#include <vector>
#include <string>
#include <algorithm>// 學生類
struct Student {int id;// 學號std::string name;// 名字double score;// 分數// 打印學生信息void print() const {std::cout << "ID: " << id << ", Name: " << name << ", Score: " << score << std::endl;}
};// 管理員類
class Admin {
public:// 添加學生void addStudent(int id, const std::string& name, double score) {students.push_back({ id, name, score });// 會調用默認的構造函數生成匿名學生std::cout << "添加學生成功!" << std::endl;}// 刪除學生void deleteStudent(int id) {auto it = std::remove_if(students.begin(), students.end(), [id](const Student& s) {return s.id == id;});if (it != students.end()) {students.erase(it,students.end());std::cout << "刪除學生成功!" << std::endl;}else {std::cout << "學生不存在!" << std::endl;}}// 查找學生void findStudent(int id) const {auto it = std::find_if(students.begin(), students.end(), [id](const Student& s) {return s.id == id;});if (it != students.end()) {it->print();// 調用學生的打印}else {std::cout << "學生不存在!" << std::endl;}}// 更新學生void updateStudent(int id, const std::string& newName, double newScore) {auto it = std::find_if(students.begin(), students.end(), [id](const Student& s) {return s.id == id;});if (it != students.end()) {it->name = newName;it->score = newScore;std::cout << "更新學生成功!" << std::endl;}else {std::cout << "學生不存在!" << std::endl;}}// 列出所有學生信息void listAllStudents() const {for (const auto& student : students) {student.print();}}
private:std::vector<Student> students;//用數組存儲學生
};int main() {Admin manager;std::string name;int id = 0;double score = 0.0;int choice = 0;while (true) {std::cout << "1. 添加學生" << std::endl;std::cout << "2. 刪除學生" << std::endl;std::cout << "3. 查找學生" << std::endl;std::cout << "4. 更新學生" << std::endl;std::cout << "5. 列出所有學生信息" << std::endl;std::cout << "6. 退出" << std::endl;std::cout << "Enter your choice: ";std::cin >> choice;switch (choice) {case 1:std::cout << "請輸入學號 姓名 分數";std::cin >> id >> name >> score;manager.addStudent(id, name, score);break;case 2:std::cout << "請輸入要刪除學生的學號";std::cin >> id;manager.deleteStudent(id);break;case 3:std::cout << "請輸入要查找學生的學號";std::cin >> id;manager.findStudent(id);break;case 4:std::cout << "請輸入要更新學生的學號,姓名,分數";std::cin >> id >> name >> score;manager.updateStudent(id, name, score);break;case 5:manager.listAllStudents();break;case 6:return 0;// 表正常退出default:std::cout << "輸入不合法,請重新輸入" << std::endl;}}return 0;
}

remove_if

???????remove_if是 C++ <algorithm> 頭文件中的一個算法,?將不符合條件的元素移動到前面,并返回新的結束迭代器,需要配合容器的 erase() 方法來真正刪除元素(再刪除一段訪問)

#include <algorithm>  // std::remove_if
#include <vector>     // std::vector
#include <iostream>   // std::cout
using namespace std;int main() {std::vector<int> vec = {1,3, 4, 5, 6};auto end_begin =  std::remove_if(vec.begin(), vec.end(), [](int x){return x % 2 == 0;//移除所有偶數});vec.erase(end_begin, vec.end());// 刪除一段訪問for (int n : vec) {std::cout << n << " ";  // 輸出:1 3 5}cout << endl;
}

find_if

????????find_if 是 C++ <algorithm> 頭文件中的一個算法,用于查找容器中第一個符合指定條件的元素,并返回指向該元素的迭代器。如果找不到,則返回 end() 迭代器?

#include <iostream>
#include <vector>
#include <algorithm> // std::find_ifint main() {std::vector<int> vec = {1, 3, 5, 4, 6, 7};auto it = std::find_if(vec.begin(), vec.end(), [](int x){return x % 2 == 0;});if (it != vec.end()) {std::cout << "找到第一個偶數:" << *it << std::endl; // 輸出:找到第一個偶數:4} else {std::cout << "未找到偶數" << std::endl;}
}

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/bicheng/73326.shtml
繁體地址,請注明出處:http://hk.pswp.cn/bicheng/73326.shtml
英文地址,請注明出處:http://en.pswp.cn/bicheng/73326.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

大語言模型基礎—語言模型的發展歷程--task1

目錄 1.語言模型的發展歷程 1.1 統計語言模型 1.2 神經語言模型 1.3 預訓練語言模型 1.4 大語言模型 1.5 總結 1.6 各階段對比與演進邏輯 1.語言模型的發展歷程 語言模型的發展歷程經歷了四個主要階段&#xff1a;統計語言模型、神經語言模型、預訓練語言模型和大語言模…

BIG_EVENT

環境準備: 開發: 跨域問題: 只有瀏覽器才存在跨域問題, 此時瀏覽器的地址和前端服務一致,所以不存在跨域問題, 但是當瀏覽器中的js代碼需要向8080發送請求時就會由于存在跨域問題而失敗. 簡單的說前端和瀏覽器的地址端口是一致的,瀏覽器只能向前端服務發送請求, 所以可以使用配…

DAY33 貪心算法Ⅱ

122. 買賣股票的最佳時機 II - 力扣&#xff08;LeetCode&#xff09; 想到把整體利潤分解為每天的利潤&#xff0c;就豁然開朗了。 class Solution { public:int maxProfit(vector<int>& prices) {int result0;for(int i1;i<prices.size();i){resultmax(0,pric…

【Qt】qApp簡單介紹

1. 介紹 在Qt中&#xff0c;qApp是一個全局指針&#xff0c;它指向當前的QApplication或QGuiApplication對象。這個全局指針在Qt應用程序中非常有用&#xff0c;因為它可以讓你在任何地方訪問到應用程序對象。 在C中&#xff0c;全局指針是一個可以在程序的任何地方訪問的指針…

Redis 設置密碼無效問題解決

一、驗證密碼有沒有生效 運行cmd&#xff0c;cd到redis的目錄下 輸入“redis-cli.exe” 回車 輸入“auth 123456” 回車 若錯誤&#xff0c;說明沒有設置密碼或者設置的密碼沒有生效 輸入“exit” 回車就立即退出redis 二、解決方案是&#xff1a;直接修改后綴是 .conf 的…

手寫一些常見算法

手寫一些常見算法 快速排序歸并排序Dijkstra自定義排序交替打印0和1冒泡排序插入排序堆排序 快速排序 public class Main {public static void main(String[] args) {int nums[] {1,3,2,5,4,6,8,7,9};quickSort(nums,0,nums.length - 1);}private static void quickSort(int[…

VBA即用型代碼手冊:選擇、轉到Select、 Go To

我給VBA下的定義&#xff1a;VBA是個人小型自動化處理的有效工具。可以大大提高自己的勞動效率&#xff0c;而且可以提高數據的準確性。我這里專注VBA,將我多年的經驗匯集在VBA系列九套教程中。 作為我的學員要利用我的積木編程思想&#xff0c;積木編程最重要的是積木如何搭建…

[CISSP] [1] 訪問控制//入侵檢測與網絡防護

訪問控制 檢測性訪問控制&#xff08;Detective Access Control&#xff09; 作用&#xff1a;用于發現和記錄未經授權的活動。方式&#xff1a;這類控制本身不直接阻止攻擊或違規行為&#xff0c;而是監測、檢測并記錄這些事件&#xff0c;以便后續調查或響應。例子&#xff1…

【SpringBoot】MD5加鹽算法的詳解

目錄 一、什么是加鹽算法 二、如何實現加鹽算法 2.1 加鹽算法代碼實現 2.2 注冊頁面中進行密碼加鹽 2.3 登錄頁面進行加鹽的解密 2.4 注冊和登錄 一、什么是加鹽算法 加鹽算法是一種用于增強密碼安全性的技術。這種技術通過在密碼存儲過程中添加一個隨機生成的鹽值&…

uniapp移動端圖片比較器組件,仿英偉達官網rtx光追圖片比較器功能

組件下載地址&#xff1a;https://ext.dcloud.net.cn/plugin?id22609 已測試h5和微信小程序&#xff0c;理論支持全平臺 亮點&#xff1a; 簡單易用 使用js計算而不是resize屬性&#xff0c;定制化程度更高 組件掛在后可播放指示線動畫&#xff0c;提示用戶可以拖拽比較圖片…

CI/CD—Jenkins實現自動構建Docker鏡像運行Java程序

實現原理 1、Java代碼中創建一個dockerfile文件 --> 2、代碼上傳至GitLab --> 3、Jenkins同步GitLab的代碼進行構建生成jar --> 4、Jenkins將jar包和dockerfile文件傳到測試服務器上 --> 5、在測試服務器上執行dockerfile構建jar鏡像 --> 6、鏡像構建完運行容器…

docker 搭建alpine下nginx1.26/mysql8.0/php7.4環境

docker 搭建alpine下nginx1.26/mysql8.0/php7.4環境 docker-compose.yml services:mysql-8.0:container_name: mysql-8.0image: mysql:8.0restart: always#ports:#- "3306:3306"volumes:- ./etc/mysql/conf.d/mysql.cnf:/etc/mysql/conf.d/mysql.cnf:ro- ./var/log…

隊列的簡單例題

題目如下 模擬隊列 首先你要明白隊列的話 只有隊尾才能進行新增&#xff0c;也就是入隊 只有隊首才能出隊&#xff0c;也就是刪除 隊首隊尾指針一開始默認都是0 相當于隊列中一開始是有一個元素的就是 0的位置 隊首指針head0 隊尾指針tail0 1.入隊也就是隊尾要先賦值&#xf…

vue3+elementuiplus的table表格動態高度

table表格流體高度 1、前提 了解自定義指令、hooks 2、核心思路 通過自定義指令&#xff08;new ResizeObserver&#xff09;監聽表格變化&#xff0c;然后通過hooks去更新表格高度。 3、核心代碼 src/directives/resize.ts // import { debounce } from /utils;import { t…

Apache POI詳解

目錄 前言 Apache POI是一個強大的Java庫&#xff0c;廣泛用于處理Microsoft Office文檔&#xff0c;包括Word、Excel和PowerPoint等。本文將詳細介紹如何使用Apache POI庫操作Word模板&#xff08;包括替換占位符、操作表格&#xff09;、將Word文檔轉換為PDF&#xff0c;以及…

AutoGen多角色、多用戶、多智能體對話系統

2023-03-11-AutoGen 使用【autoGenchainlitdeepSeek】實現【多角色、多用戶、多智能體對話系統】 1-核心思路 01&#xff09;技術要點&#xff1a;autoGenchainlitdeepSeek02&#xff09;什么是autoGen->autogen是微軟旗下的多智能體的框架03&#xff09;什么是chainlit-&g…

問deepseek: OpenFOAM并行分區后,是如何實現ldumatrix矩陣向量乘法計算邏輯的?

在OpenFOAM中&#xff0c;lduMatrix 是用于存儲稀疏矩陣的類&#xff0c;支持并行計算。并行分區后&#xff0c;lduMatrix 的矩陣向量乘法通過以下步驟實現&#xff1a; 1. 矩陣分區 分區&#xff1a;將矩陣和向量分配到多個處理器上&#xff0c;每個處理器負責一部分。接口&…

數據類設計_圖片類設計之4_規則類圖形混合算法(前端架構)

前言 學的東西多了,要想辦法用出來.C和C是偏向底層的語言,直接與數據打交道.嘗試做一些和數據方面相關的內容 引入 接續上一篇,討論圖片類型設計出來后在場景中如何表達,以及圖片的混合算法.前面的內容屬于鋪墊和基礎,這篇內容和實際聯系起來了. 背景圖和前景圖 這里筆者想先…

【openwebui 搭建本地知識庫(RAG搭建本地知識庫)】

安裝準備 openwebui 這個本地安裝之前寫過使用python安裝。也可以直接用docker 命令 docker run --rm -d \-p 3080:8080 \-p 3081:8081 \-e WEBUI_AUTHtrue \-e DEFAULT_LOCALEcn \-e GLOBAL_LOG_LEVEL"INFO" \-e AIOHTTP_CLIENT_TIMEOUT100 \--privilegedtrue \-…

Nginx的流式響應配置詳解

現在大模型場景繁多&#xff0c;項目中涉及nginx轉發大模型的流式數據時&#xff0c;需配置nginx的轉發策略&#xff1a; location /streaming {proxy_pass http://backend_server;proxy_cache off; # 關閉緩存proxy_buffering off; # 關閉代理緩沖chunked_transfer_encoding …