Java模拟算法题目练习

Java模拟算法题目练习

模拟算法

模拟算法就是根据其题目进行一步一步操作即可,相对而言较简单,但是边界情况要处理好(细节问题)

替换所有的问好

在这里插入图片描述
题目解析:将s字符串中的?全部替换成小写字母,并且替换?的字符不可以与原本?相邻的两个字符相等
模拟:只需要根据题目条件,找出所有?,并将其替换成符合要求的小写字母即可
在这里插入图片描述
classSolution{publicStringmodifyString(String ss){//替换问好,但是相邻的不可以重复int n = ss.length();char[] s = ss.toCharArray();for(int i =0; i < n;i++){if(s[i]=='?'){//找一个符合条件的字母替换for(char ch ='a'; ch <'z';ch++){//注意?在最左边和最右边这两个边界情况if((i==0|| s[i-1]!= ch)&&(i == n-1|| s[i+1]!= ch)){ s[i]= ch;break;}}}}returnString.valueOf(s);}}
时间复杂度:O(n)
空间复杂度:O(n)

提莫攻击

在这里插入图片描述
题目解析:提莫会对艾希释放技能,让艾希处于中毒状态,求出中毒的总时间
模拟:会出现一次技能持续时间还没有结束,又释放了一个技能
因此我们要判断相邻两次释放技能时间差值与技能持续时间进行对比
如果差值大于或者等于技能持续时间,总时间就加上duration
反之,总时间就加上差值
但是这加上的都是上一次技能的持续时间,因此最后要加上duration,因为最后一次技能肯定会执行完
在这里插入图片描述
classSolution{publicintfindPoisonedDuration(int[] timeSeries,int duration){//判断这次攻击与上次攻击的时间差值即可//差值 >= duration,上一次执行时间为duration//反之 < duration, 上一次执行的时间就是差值int sum =0;for(int i =1;i < timeSeries.length;i++){int x = timeSeries[i]- timeSeries[i -1];if(x >= duration){ sum += duration;}else{ sum += x;}}//加上最后一次技能的持续时间return sum + duration;}}
时间复杂度:O(n)
空间复杂度:O(1)

Z字形变换

在这里插入图片描述
题目解析:给一个字符串,输出其Z字形转换后,按行放入一个新的字符串中返回
模拟:可以直接将其全部字符按照Z字形放到二维矩阵中,并遍历即可,但是时间复杂度和空间复杂度较高,因此我们看看可以找规律吗
在这里插入图片描述
在这里插入图片描述
此时要注意当n = 1时候,其可能会死循环,因此要判断一下
classSolution{publicStringconvert(String s,int numRows){if(numRows <2){return s;}int n = s.length();//公差int d =2*numRows -2;StringBuffer ret =newStringBuffer();//第一行for(int i =0;i < n;i += d){ ret.append(s.charAt(i));}//中间行for(int k =1;k < numRows -1;k++){for(int i = k,j = d - i;i < n||j< n;i += d,j += d){if(i < n){ ret.append(s.charAt(i));}if(j < n){ ret.append(s.charAt(j));}}}for(int i = numRows-1;i < n;i += d){ ret.append(s.charAt(i));}return ret.toString();}}
时间复杂度:O(n)
空间复杂度:O(n)

外观数列

在这里插入图片描述
题目解析:就是有很多行的字符串,每一行字符串都是解释的上一行字符串,找出第n行字符串
模拟+双指针
在这里插入图片描述
classSolution{publicStringcountAndSay(int n){//一直解释,解释到第n行String ret ="1";for(int i =1; i < n;i++){//存放当前这一行的解释StringBuilder tem =newStringBuilder();//当前行的长度int len = ret.length();//开始解释for(int left =0,right =0;right < len;){while(right < len&&ret.charAt(left)== ret.charAt(right)){ right++;//直到不相同为止} tem.append(Integer.toString(right - left)); tem.append(ret.charAt(left)); left = right;} ret = tem.toString();}return ret;}}

数青蛙

在这里插入图片描述
题目解析:给了一个字符串,求最小青蛙数量,这里完整的croak才是哇叫,如果存在不完整的就返回-1
模拟+哈希表
因此每次遍历到那个字符都要判断其前驱字符是否存在
使用一个数组放croak对应元素个数
因为这里要找前驱,所以一个哈希表,存放croak这些字符对应下标关系,这样可以对应到上面数组中个数
在这里插入图片描述
在这里插入图片描述


在这里插入图片描述


在这里插入图片描述
可以直接使用5个变量记录这个字符出现的个数,不断if else即可
classSolution{publicintminNumberOfFrogs(String croakOfFrogs){if(croakOfFrogs.length()%5!=0){return-1;}int c =0;int r =0;int o =0;int a =0;int k =0;int ret =0;for(int i =0; i < croakOfFrogs.length(); i++){char ch = croakOfFrogs.charAt(i);//每次都哟啊判断其前驱字符个数if(ch =='c'){//判断又没有青蛙叫完,有的话就可以从后面直接调取即可if(k >0){--k;++c;}else{++c;}}elseif(ch =='r'){if(c ==0){return-1;}else{--c;++r;}}elseif(ch =='o'){if(r ==0){return-1;}else{--r;++o;}}elseif(ch =='a'){if(o ==0){return-1;}else{--o;++a;}}else{if(a ==0){return-1;}else{--a;++k;}}}if(c!=0||r!=0||o!=0||a!=0){return-1;}return k;}}
使用数组存放对应数量,哈希表来对应下标关系
classSolution{publicintminNumberOfFrogs(String croakOfFrogs){//使用数组模拟哈希String t ="croak";int n = t.length();int[] hash =newint[n];//存放对应元素个数//使用哈希表来映射他们的下标Map<Character,Integer> map =newHashMap<>();//先放入哈希中for(int i =0;i < n;i++){ map.put(t.charAt(i),i);}//此时就要开始判断for(char ch : croakOfFrogs.toCharArray()){//如果是c字符要进行判断,k是否存在if(ch == t.charAt(0)){if(hash[n-1]!=0){ hash[n-1]--;} hash[0]++;}else{//中间字符//因为要判断前驱字符,这里要获取下标int index = map.get(ch);if(hash[index -1]==0){return-1;}else{ hash[index-1]--; hash[index]++;}}}//最后要判断其除了k字符,前面字符是否还有for(int i =0;i < n-1;i++){if(hash[i]!=0){return-1;}}return hash[n-1];}}

Read more

PandaWiki:更轻量的开源知识库,问答效果到底如何?(本地部署教程+效果实测)

PandaWiki:更轻量的开源知识库,问答效果到底如何?(本地部署教程+效果实测)

开源 RAG 项目我之前主要围绕 RAGFlow 写了不少落地案例。RAGFlow 定位是大而全的企业级 RAG 引擎,所以社区里也一直有人吐槽:资源吃得多、处理慢。但这事儿某种程度上就是端到端全包(解析、切分、向量化、检索、权限、工作流、评测)的代价,工程体量上去了,默认就不可能太轻。 如果你想找一款更轻量的开源方案,主要用来处理产品文档、技术文档、FAQ、博客等内容,那可以看看今天要介绍的 PandaWiki。一句话总结:PandaWiki 更像开源版的知识库产品,而不是一个给工程师从零拼装的 RAG 引擎。 这个项目实际我也是近期才注意到,GitHub 目前 8.6K Star,看趋势图下半年热度是一路走高。我花了几天集中测了下,确实有一些可圈可点的地方,这篇就抓大放小,来和各位说道说道。 这篇试图说清楚: PandaWiki 的手把手本地部署过程、

By Ne0inhk

3大开源修复模型横评:云端镜像快速部署,1天完成全面测试

3大开源修复模型横评:云端镜像快速部署,1天完成全面测试 你是不是也遇到过这样的情况:团队要选一个AI图像修复工具,大家各自在本地跑GFPGAN、CodeFormer、GPEN,结果有人用笔记本CPU跑,有人用高端显卡,测试速度、画质效果完全没法比?最后开会讨论时,谁的电脑配置高,谁的结果就“看起来更好”,根本没法做出公正决策。 这正是很多技术主管在搭建AI工具链时最头疼的问题——缺乏统一、可复现的测试环境。不同设备、不同依赖版本、不同参数设置,导致评估结果偏差巨大,选型变成“看运气”。 别急,今天我就来帮你解决这个痛点。我们不靠本地部署“拼电脑”,而是直接上云端标准化镜像环境,一键部署三大主流开源人脸修复模型:GFPGAN、CodeFormer 和 GPEN,在相同GPU资源下完成公平对比测试,1天内搞定从部署到出报告的全流程。 ZEEKLOG星图平台提供了预置好这三大模型的AI镜像,无需手动安装复杂依赖,不用折腾CUDA、PyTorch版本兼容问题,点击即用,还能对外暴露API服务,方便团队成员远程调用测试。整个过程就像租了一台“AI修复工作站”,谁都能用,结果可比对。

By Ne0inhk
手把手教你在GitHub上运行开源项目(新手必看版)

手把手教你在GitHub上运行开源项目(新手必看版)

📦 说在前面 GitHub这个程序员宝藏平台(我愿称之为代码界的金矿),每天都有成千上万的开源项目更新。但是很多新手朋友看到那些酷炫项目时,经常会遇到三大灵魂拷问:这项目怎么跑起来?需要装什么软件?报错了怎么办?今天咱们就用最接地气的方式,手把手教你从0到1运行GitHub项目! 🔧 准备工具包(装机三件套) 1. 代码编辑器(必装) 推荐直接上VS Code这个万金油,装好记得在扩展商店安装这两个插件: * GitLens(代码时光机,能看到每行代码的修改记录) * Code Runner(一键运行脚本的神器) (超级重要)👉 如果项目里有.vscode文件夹,一定要用VS Code打开,里面可能有预置的调试配置! 2. Git客户端(下载代码必备) Windows用户直接装Git for Windows,安装时记得勾选这个选项: Use Git and optional Unix tools from the Command Prompt (这样就能在CMD里用Linux命令了,真香!

By Ne0inhk
弃用MobaXterm,拥抱开源软件Tabby

弃用MobaXterm,拥抱开源软件Tabby

目录 * 引言 * MobaXterm * MobaXterm - Windows下的增强型终端 * 🚀 核心功能点 * 🖥️ X服务器功能 * 💻 终端功能 * 🌐 网络协议支持 * 📁 文件管理功能 * 🔧 高级功能 * 🎨 界面定制 * 📊 会话管理 * 🔌 插件系统 * 🔒 安全功能 * 📱 便携特性 * 🌍 多语言支持 * 📈 专业版增强功能 * 版本说明: * 🔹 家庭版 (Home Edition) * 🔸 专业版 (Professional Edition) * 企业使用建议: * 使用场景: * Tabby * Tabby - 现代化的终端模拟器 * 🚀 核心功能点 * 💻 终端功能 * 🎨 界面定制 * 🔗 网络连接功能 * SSH客户端 * 其他协议 *

By Ne0inhk