当前位置: 首页 > article >正文

用C++手搓一个‘密码发生器’:从蓝桥杯真题到实用小工具(附完整源码)

用C手搓一个‘密码发生器’从蓝桥杯真题到实用小工具附完整源码在编程学习的过程中算法竞赛题往往给人一种高冷的印象——它们通常专注于考察特定的解题技巧却很少考虑实际应用场景。但如果我们换个视角这些题目中的算法逻辑往往能成为构建实用工具的绝佳素材。今天我们就以蓝桥杯LQ0274密码发生器为例看看如何将一道看似简单的竞赛题改造成一个既有趣味性又有实用价值的C小工具。这个工具的核心功能很简单将用户输入的拼音字符串比如名字转换为6位数字密码。虽然算法本身来自竞赛题但经过适当封装和功能扩展后它可以成为一个有趣的个性化密码生成器——你可以用它为不同账号生成易记又不易被破解的密码或者单纯当作一个记忆训练的小玩具。下面让我们一步步实现这个蜕变。1. 理解原始算法逻辑原始题目描述了一个三步转换过程字符串分组将输入字符串按6个字符一组进行折叠ASCII码求和对每组中同一位置的字符ASCII码值求和数字缩位将求和结果不断各位相加直到得到一位数例如输入wangximing的处理过程分组 wangxi ming 垂直求和 w(119) m(109) 228 a(97) i(105) 202 n(110) n(110) 220 g(103) g(103) 206 x(120) (无) 120 i(105) (无) 105 缩位处理 228 → 22812 → 123 202 → 2024 220 → 2204 206 → 2068 120 → 1203 105 → 1056 最终密码3448362. 基础实现竞赛代码解析原始AC代码已经实现了核心算法#include iostream #include cstring using namespace std; const int N 6; int sum[N]; int getsum(int n) { int r 0; while (n) r n % 10, n / 10; return r; } int main() { int n; string s; cin n; while (n--) { cin s; memset(sum, 0, sizeof sum); for (int i 0; s[i]; i) sum[i % N] s[i]; for (int i 0; i N; i) { int d getsum(sum[i]); while (d 10) d getsum(d); printf(%d, d); } printf(\n); } return 0; }这段代码有几个特点使用sum数组存储6个位置的和getsum函数实现数字各位相加主循环处理多组输入输出虽然功能完整但从工程角度看存在几个可以改进的地方输入输出与业务逻辑耦合缺乏错误处理和输入验证代码可读性和可维护性有待提高3. 工程化改造构建PasswordGenerator类让我们将核心算法封装成一个独立的类提高代码的复用性和可维护性#include iostream #include string #include vector #include stdexcept class PasswordGenerator { public: static const int PASSWORD_LENGTH 6; // 生成密码的公开接口 static std::string generate(const std::string input) { validateInput(input); return process(input); } private: // 输入验证 static void validateInput(const std::string input) { if (input.empty()) { throw std::invalid_argument(Input string cannot be empty); } } // 核心处理逻辑 static std::string process(const std::string input) { int sums[PASSWORD_LENGTH] {0}; // 第一步分组并求和 for (size_t i 0; i input.size(); i) { sums[i % PASSWORD_LENGTH] static_castint(input[i]); } // 第二步缩位处理 std::string result; for (int i 0; i PASSWORD_LENGTH; i) { result std::to_string(reduceToSingleDigit(sums[i])); } return result; } // 将数字缩减为一位数 static int reduceToSingleDigit(int number) { while (number 10) { number digitSum(number); } return number; } // 计算数字各位之和 static int digitSum(int number) { int sum 0; while (number ! 0) { sum number % 10; number / 10; } return sum; } };这个改进版使用面向对象封装添加输入验证分离核心算法与I/O使用更清晰的命名添加异常处理4. 功能扩展打造实用小工具现在我们可以基于这个核心类构建更实用的功能4.1 交互式命令行工具#include iostream #include PasswordGenerator.h void runInteractiveMode() { std::cout 密码生成器 std::endl; std::cout 输入q退出 std::endl std::endl; while (true) { std::cout 请输入拼音字符串: ; std::string input; std::getline(std::cin, input); if (input q) break; try { std::string password PasswordGenerator::generate(input); std::cout 生成的密码: password std::endl std::endl; } catch (const std::exception e) { std::cerr 错误: e.what() std::endl; } } } int main() { runInteractiveMode(); return 0; }4.2 批量处理模式void processBatch(const std::vectorstd::string inputs) { std::cout 批量处理结果: std::endl; for (const auto input : inputs) { try { std::string password PasswordGenerator::generate(input); std::cout input → password std::endl; } catch (const std::exception e) { std::cerr input → 错误: e.what() std::endl; } } }4.3 添加盐值增强安全性虽然这个密码生成器主要用于趣味用途但我们可以通过添加盐值来增加密码的随机性class EnhancedPasswordGenerator : public PasswordGenerator { public: static std::string generateWithSalt(const std::string input, const std::string salt) { std::string combined input salt; return generate(combined); } };5. 实际应用场景探讨这个简单的密码发生器虽然不能替代专业的密码管理工具但在某些场景下仍有用武之地记忆辅助为不同服务生成易记的个性化密码例如用taobao你的名字生成淘宝密码用wechat你的名字生成微信密码游戏道具命名为游戏角色或道具生成唯一编号临时密码需要快速生成一次性密码的场景编程教学演示算法实用化的典型案例注意请不要将此工具用于重要账户的真实密码生成因为它不具备真正的密码学强度。6. 性能优化与进阶改进如果需要处理大量数据或追求更高性能我们可以考虑以下优化6.1 并行计算优化#include thread #include algorithm std::string parallelProcess(const std::string input) { int sums[PASSWORD_LENGTH] {0}; std::vectorstd::thread workers; // 为每个位置创建独立的工作线程 for (int i 0; i PASSWORD_LENGTH; i) { workers.emplace_back([i, input, sums]() { for (size_t j i; j input.size(); j PASSWORD_LENGTH) { sums[i] static_castint(input[j]); } }); } // 等待所有线程完成 for (auto t : workers) { t.join(); } // 缩位处理 std::string result; for (int i 0; i PASSWORD_LENGTH; i) { result std::to_string(reduceToSingleDigit(sums[i])); } return result; }6.2 支持宽字符集std::string generateUnicode(const std::wstring wideInput) { std::string narrowStr(wideInput.begin(), wideInput.end()); return generate(narrowStr); }6.3 添加GUI界面使用Qt等框架创建图形界面// Qt示例代码片段 void MainWindow::on_generateButton_clicked() { QString input ui-inputEdit-text(); if (input.isEmpty()) { QMessageBox::warning(this, 错误, 请输入有效内容); return; } try { std::string password PasswordGenerator::generate(input.toStdString()); ui-resultLabel-setText(QString::fromStdString(password)); } catch (const std::exception e) { QMessageBox::critical(this, 错误, e.what()); } }7. 测试与验证良好的测试是确保工具可靠性的关键#include gtest/gtest.h TEST(PasswordGeneratorTest, BasicTest) { EXPECT_EQ(PasswordGenerator::generate(wangximing), 344836); EXPECT_EQ(PasswordGenerator::generate(zhangfeng), 772243); } TEST(PasswordGeneratorTest, EdgeCases) { // 测试短字符串 EXPECT_EQ(PasswordGenerator::generate(a), 100000); // 测试空字符串 EXPECT_THROW(PasswordGenerator::generate(), std::invalid_argument); } TEST(EnhancedGeneratorTest, SaltTest) { EXPECT_NE( EnhancedPasswordGenerator::generateWithSalt(wang, 123), EnhancedPasswordGenerator::generateWithSalt(wang, 456) ); }8. 完整实现与使用示例以下是整合所有功能的完整实现示例// PasswordGenerator.h #include string #include stdexcept class PasswordGenerator { public: static const int PASSWORD_LENGTH 6; static std::string generate(const std::string input) { validateInput(input); int sums[PASSWORD_LENGTH] {0}; for (size_t i 0; i input.size(); i) { sums[i % PASSWORD_LENGTH] static_castint(input[i]); } std::string result; for (int i 0; i PASSWORD_LENGTH; i) { result std::to_string(reduceToSingleDigit(sums[i])); } return result; } protected: static void validateInput(const std::string input) { if (input.empty()) { throw std::invalid_argument(Input string cannot be empty); } } static int reduceToSingleDigit(int number) { while (number 10) { number digitSum(number); } return number; } static int digitSum(int number) { int sum 0; while (number ! 0) { sum number % 10; number / 10; } return sum; } }; class EnhancedPasswordGenerator : public PasswordGenerator { public: static std::string generateWithSalt(const std::string input, const std::string salt) { return generate(input salt); } };使用示例#include iostream #include PasswordGenerator.h int main() { std::cout 简单密码生成器演示 std::endl; // 基本用法 std::cout wangximing → PasswordGenerator::generate(wangximing) std::endl; // 增强版带盐值 std::cout wangximingsalt123 → EnhancedPasswordGenerator::generateWithSalt(wangximing, salt123) std::endl; // 交互模式 std::string input; while (true) { std::cout \n输入要转换的字符串(或q退出): ; std::getline(std::cin, input); if (input q) break; try { std::cout 生成的密码: PasswordGenerator::generate(input) std::endl; } catch (const std::exception e) { std::cerr 错误: e.what() std::endl; } } return 0; }这个密码生成器虽然源于一道简单的竞赛题但经过适当的设计和扩展它已经变成了一个具有一定实用价值的小工具。更重要的是这个过程展示了如何将算法题目中的核心思想提取出来经过工程化改造后应用到实际场景中。

相关文章:

用C++手搓一个‘密码发生器’:从蓝桥杯真题到实用小工具(附完整源码)

用C手搓一个‘密码发生器’:从蓝桥杯真题到实用小工具(附完整源码) 在编程学习的过程中,算法竞赛题往往给人一种"高冷"的印象——它们通常专注于考察特定的解题技巧,却很少考虑实际应用场景。但如果我们换个…...

用VOFA+可视化调PID速度环,告别盲调!手把手教你从串口数据到实时波形

用VOFA实现PID速度环可视化调参:从数据采集到参数优化的完整指南 调试嵌入式系统中的PID控制器时,最令人头疼的莫过于反复修改参数、下载程序、观察日志的循环。传统调试方式就像在黑暗中摸索,而VOFA的出现为工程师们点亮了一盏明灯。本文将…...

告别枯燥调试!用Arduino UNO + DFPlayer Mini做个桌面音乐盒(附完整代码与文件命名避坑指南)

用Arduino UNO与DFPlayer Mini打造智能桌面音乐盒:从硬件组装到文件命名的完整指南 周末午后,阳光透过窗户洒在桌面上,一个木质外壳的小盒子突然响起你最爱的钢琴曲——这不是普通的蓝牙音箱,而是你用Arduino亲手制作的智能音乐盒…...

AI-Parl框架:构建多智能体对话系统的轻量级解决方案

1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目,叫mahaoran1997/ai-parl。光看名字,你可能会觉得这又是一个“AIXX”的缝合怪项目,但点进去仔细研究后,我发现它的定位相当精准,解决的是一个在AI应用开发中…...

告别FTP和网盘:用Remmina在国产系统与Windows间搭建无缝文件互传工作流

告别FTP和网盘:用Remmina在国产系统与Windows间搭建无缝文件互传工作流 在混合办公环境中,设计师修改完PSD源文件需要同步给Windows同事,文案专员要将统信UOS上的文档传给合作方,运维人员需在麒麟KYLINOS服务器与Windows客户端间传…...

用LAVIS-BLIP2模型,5分钟搞定图片描述和视觉问答(附完整代码)

5分钟实战:用LAVIS-BLIP2打造智能图片理解系统 在数字内容爆炸式增长的今天,如何让机器"看懂"图片并与人自然交互已成为AI领域的热点。LAVIS-BLIP2作为多模态AI的瑞士军刀,让开发者无需深入模型细节就能快速构建图像理解应用。本文…...

告别硬编码!手把手教你用Flink自定义Source优雅读取MySQL数据(附完整Java代码)

从零构建企业级Flink MySQL Source:可配置化与生产实践指南 在实时数据处理领域,Flink已成为事实上的标准框架之一。但当我们真正将其应用于生产环境时,往往会发现官方文档中的示例代码与实际情况存在巨大鸿沟——特别是当数据源来自传统关系…...

告别信息丢失!用PyTorch实现Haar小波下采样模块,提升语义分割细节表现(附完整代码)

用PyTorch实现Haar小波下采样:提升语义分割细节的工程实践 在语义分割任务中,边界清晰度和纹理保留能力往往是决定模型性能的关键因素。传统下采样方法如最大池化或跨步卷积虽然计算高效,却不可避免地造成高频信息丢失——这正是许多分割网络…...

UV展开技术:ABF++与LSCM算法对比与优化实践

1. UV展开技术背景与核心挑战UV展开作为三维模型纹理映射的基础环节,直接影响着后续贴图绘制的精度与效率。在游戏开发、影视动画等数字内容创作领域,艺术家们经常需要处理数百万面片的高模展开工作。传统展开方法在处理复杂拓扑结构时容易出现拉伸、重叠…...

Windows系统维护革命:Dism++如何让复杂操作变得简单

Windows系统维护革命:Dism如何让复杂操作变得简单 【免费下载链接】Dism-Multi-language Dism Multi-language Support & BUG Report 项目地址: https://gitcode.com/gh_mirrors/di/Dism-Multi-language 你是否曾因Windows系统越来越臃肿而烦恼&#xff…...

深入解析immortal-skill:模块化技能执行框架的设计与实战

1. 项目概述与核心价值最近在GitHub上看到一个挺有意思的项目,叫“agenmod/immortal-skill”。光看这个名字,可能有点摸不着头脑,又是“agenmod”,又是“不朽技能”的。但作为一个常年混迹在开源社区,喜欢折腾各种自动…...

AI编程工作流实战:基于MCP协议整合Claude、Cursor等多助手

1. 从“工具集”到“工作流”:重新定义AI辅助编程最近在GitHub上看到一个名为“awesome-vibe-coding-tools”的项目,它本质上是一个打包了多种AI编程辅助工具的集合。作为一个在开发一线摸爬滚打了十多年的老码农,我对这类“一站式工具包”的…...

音频令牌动态压缩技术:提升大语言模型语音处理效率

1. 项目概述:音频驱动的动态令牌压缩技术 在语音交互与多模态AI快速发展的今天,大语言模型处理长音频输入时面临两个关键挑战:计算资源消耗随序列长度平方级增长,以及语音信息中存在大量冗余信号。OmniZip技术通过实时分析音频频谱…...

告别繁琐配置!Win11下用Go一键编译fscan内网扫描器的保姆级教程

Win11极简编译指南:5分钟搞定fscan内网扫描器 每次看到那些需要配置Go环境、解决依赖问题的开源工具就头疼?作为一款高效的内网扫描工具,fscan的实用性毋庸置疑,但官方文档里那些晦涩的编译步骤确实让不少新手望而却步。今天我们就…...

惠普OMEN游戏本性能解锁全攻略:OmenSuperHub深度解析与实战指南

惠普OMEN游戏本性能解锁全攻略:OmenSuperHub深度解析与实战指南 【免费下载链接】OmenSuperHub 使用 WMI BIOS控制性能和风扇速度,自动解除DB功耗限制。 项目地址: https://gitcode.com/gh_mirrors/om/OmenSuperHub 你是否厌倦了官方OMEN Gaming …...

别再只调参数了!用UDS 2F服务控制车窗/车灯,手把手教你实战报文分析

实战UDS 2F服务:从报文构造到车窗控制的完整闭环验证 在汽车电子诊断领域,UDS协议中的2F服务(InputOutputControlByIdentifier)就像一把精准的"遥控器",允许工程师直接操控ECU的输入输出信号。但很多开发者仅…...

Fan Control:Windows系统风扇控制的终极免费解决方案

Fan Control:Windows系统风扇控制的终极免费解决方案 【免费下载链接】FanControl.Releases This is the release repository for Fan Control, a highly customizable fan controlling software for Windows. 项目地址: https://gitcode.com/GitHub_Trending/fa/…...

Python 3.12 Descriptor - 04 - classmethod

Python 3.12 Descriptor - classmethod在 Python 的面向对象编程中,类方法(class method)是一种特殊的方法,它通过 classmethod 装饰器定义,方法的第一个参数是类本身(通常命名为 cls)&#xf…...

OSINT与AI资源整合:构建高效情报分析工作流

1. 项目概述:一个为OSINT与AI从业者准备的资源宝库如果你正在从事开源情报(OSINT)工作,或者对人工智能(AI)应用充满兴趣,那么你很可能和我一样,经常面临一个核心痛点:信息…...

StardewXnbHack终极指南:轻松解压星露谷物语XNB文件的免费神器

StardewXnbHack终极指南:轻松解压星露谷物语XNB文件的免费神器 【免费下载链接】StardewXnbHack A simple one-way XNB unpacker for Stardew Valley. 项目地址: https://gitcode.com/gh_mirrors/st/StardewXnbHack 还在为星露谷物语mod制作过程中复杂的XNB文…...

APK Installer:如何在Windows上轻松安装Android应用的3个关键步骤

APK Installer:如何在Windows上轻松安装Android应用的3个关键步骤 【免费下载链接】APK-Installer An Android Application Installer for Windows 项目地址: https://gitcode.com/GitHub_Trending/ap/APK-Installer 你是否曾经想在Windows电脑上直接安装And…...

Tiny11Builder技术深度解析:基于DISM的Windows 11精简镜像构建实战指南

Tiny11Builder技术深度解析:基于DISM的Windows 11精简镜像构建实战指南 【免费下载链接】tiny11builder Scripts to build a trimmed-down Windows 11 image. 项目地址: https://gitcode.com/GitHub_Trending/ti/tiny11builder Tiny11Builder是一套基于Power…...

WarcraftHelper:魔兽争霸3终极兼容性解决方案,5分钟解锁完整游戏体验

WarcraftHelper:魔兽争霸3终极兼容性解决方案,5分钟解锁完整游戏体验 【免费下载链接】WarcraftHelper Warcraft III Helper , support 1.20e, 1.24e, 1.26a, 1.27a, 1.27b 项目地址: https://gitcode.com/gh_mirrors/wa/WarcraftHelper 还在为《…...

使用 Taotoken 聚合端点快速接入 Claude Code 提升编程效率

使用 Taotoken 聚合端点快速接入 Claude Code 提升编程效率 1. Claude Code 开发者的痛点与解决方案 在日常编程工作中,许多开发者依赖 Claude Code 进行代码补全、错误检测和智能重构。然而,直接使用单一模型服务常面临两个主要问题:模型切…...

在 Node.js 后端服务中集成 Taotoken 实现多模型聊天功能

在 Node.js 后端服务中集成 Taotoken 实现多模型聊天功能 1. 环境准备与依赖安装 在开始集成 Taotoken 之前,请确保已具备以下条件: 已注册 Taotoken 账号并获取有效的 API Key(可在控制台「API 密钥」页面创建)已安装 Node.js…...

Cursor Free VIP终极指南:一键破解AI编程助手试用限制的完整解决方案

Cursor Free VIP终极指南:一键破解AI编程助手试用限制的完整解决方案 【免费下载链接】cursor-free-vip [Support 0.45](Multi Language 多语言)自动注册 Cursor Ai ,自动重置机器ID , 免费升级使用Pro 功能: Youve re…...

HSPICE仿真结果导出全攻略:从.print到.probe,手把手教你搞定波形与数据

HSPICE仿真结果导出全攻略:从.print到.probe,手把手教你搞定波形与数据 在集成电路设计领域,HSPICE作为行业标准的仿真工具,其强大的仿真能力毋庸置疑。但很多工程师在完成仿真后,常常面临一个看似简单却至关重要的问题…...

别再手动调间距了!用CVPR LaTeX模板的\medskip和\vspace高效控制论文版面

CVPR论文排版艺术:用\vspace和\medskip打造审稿人青睐的精致版面 当你的算法创新足够亮眼时,没人应该因为糟糕的排版而低估它的价值。在CVPR这样的顶级会议中,论文不仅是学术成果的载体,更是研究者专业素养的无声代言人。我审阅过…...

告别手机卡顿!用ADB给华为手机‘瘦身’,清理这8类可卸载的系统应用

华为手机深度优化指南:用ADB精准卸载系统冗余应用 手机用久了变卡顿,存储空间总是不够用?这可能是系统预装应用在悄悄占用资源。对于华为手机用户来说,通过ADB工具卸载非必要系统应用,是一种既安全又高效的解决方案。不…...

我的数据科学工作流升级:如何把Colab、GitHub和Google Drive无缝打通做自动化分析

数据科学工作流升级:ColabGitHubGoogle Drive自动化管道实战 在数据科学领域,效率瓶颈往往不在于算法本身,而在于工作流的碎片化。我曾花费大量时间在不同平台间手动搬运数据和代码——直到构建起这套自动化管道。本文将分享如何将Colab的计算…...