【备战秋招】——算法题目训练和总结day4

news2024/9/20 14:26:30

【备战秋招】——算法题目训练和总结day4😎

  • 前言🙌
    • Fibonacci数列
      • 我的题解思路分享
      • 代码分享
    • 单词搜索
      • 我的题解思路分享
      • 代码分享
    • 杨辉三角
      • 我的题解思路分享
      • 代码分享
  • 总结撒花💞

追梦之旅,你我同行

   
😎博客昵称:博客小梦
😊最喜欢的座右铭:全神贯注的上吧!!!
😊作者简介:一名热爱C/C++,算法等技术、喜爱运动、热爱K歌、敢于追梦的小博主!

😘博主小留言:哈喽!😄各位CSDN的uu们,我是你的博客好友小梦,希望我的文章可以给您带来一定的帮助,话不多说,文章推上!欢迎大家在评论区唠嗑指正,觉得好的话别忘了一键三连哦!😘
在这里插入图片描述

前言🙌

    哈喽各位友友们😊,我今天又学到了很多有趣的知识现在迫不及待的想和大家分享一下!😘 都是精华内容,可不要错过哟!!!😍😍😍

Fibonacci数列

题目链接: Fibonacci数列

在这里插入图片描述
在这里插入图片描述

我的题解思路分享

算法思路:贪心。

  1. 首先是认真审题,结合示例理解。
  2. 可以利用三个变量,再用wile 循环进行移动求解出每一个Fib数。
  3. 利用贪心的思想,很容易想到,我们应该对一个数只进行++ 或者 - - 操作。因为既++ 又 - - ,会抵消从而浪费步数。因此我们找到 n 值 离它最近的 左、右两个Fib数即可。
  4. 取他们的差值的最小值即可。

代码分享

#include <iostream>
using namespace std;

int main()
{
    int n;
    cin >> n;
    int a = 0, b = 1 ,c = 1;
    while(c < n)
    {
        a = b;
        b = c;
        c = a + b;
    }
    cout << min(c - n, n - b);
}

单词搜索

题目链接: 单词搜索

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

我的题解思路分享

算法思路:深度优先遍历dfs

  1. 首先是认真审题,结合示例理解。
  2. 定义一个 vis 二维数组,记录dfs时,访问过的字符数组位置,从而避免重复访问已走过的位置。
  3. 定义dx和dy的数组,记录该位置的上下左右四个方向。根据题目可知,我们每次都是可以从该位置的上下左右进行搜索。
  4. dfs的设计:你给我一个需要搜索的数组,并告诉我开始搜索的位置,以及目标单词开始查找的pos下标位置。
  5. 当我们查找到单词的下标已经到达单词的最后一个下标位置时,说明我们已经找到了该单词,返回true。
  6. 每次先找到要单词字符串的起点(首字母),然后进行从该位置进行一次dfs,如果可以形成目标字符串,那么就返回true
  7. 如果不能,就进行回溯,恢复现场。然后再找到一个匹配字符的起点位置,继续进行dfs。
  8. 当两次for循环后,依旧没有返回true,那么就表明该字符串数组中,不能形成单词字符串。

代码分享

class Solution {
public:

    bool vis[101][101];//记录访问过的位置
    int dx[4] = {0,0,1,-1};//形成方向坐标
    int dy[4] = {1,-1,0,0};//形成方向坐标
    int row;
    int col;
    string target;
    bool dfs(vector<string>& board, int i , int j, int pos)
    {
    	//说明已经搜索出目标word
        if(pos == target.size() - 1)
            return true;
        for(int k = 0; k < 4; k++)
        {
        	//形成坐标方位
            int x = dx[k] + i;
            int y = dy[k] + j;
            if(x >= 0 && x < row && y >= 0 && y < col  && !vis[x][y] && board[x][y] == target[pos + 1])
            {
                vis[x][y] = true;
                if(dfs(board,x,y,pos + 1))
                {
                	//剪枝:搜索到了单词,就直接返回了
                    return true;
                }
                //恢复现场
                vis[x][y] = false;
            }
        }
        //四个方位都没有路可走,说明搜索不了word。
        return false;
    }
    bool exist(vector<string>& board, string word) {
        target = word;
        row = board.size();
        col = board[0].size();
        for(int i = 0; i < row; i++)
        {
            for(int j = 0; j < col; j++)
            {
                if(board[i][j] == word[0])
                {
                    vis[i][j] = true;
                    if(dfs(board,i,j,0))
                    {
                    	//剪枝:搜索到了单词,就直接返回了
                        return true;
                    }
                    //恢复现场
                    vis[i][j] = false;
                }
            }
        }
        //遍历完整个数组,还是没有返回true,说明该本次dfs单词搜索不成功
        return false;
    }
};

杨辉三角

题目链接: 杨辉三角

在这里插入图片描述
在这里插入图片描述

我的题解思路分享

算法思路:动态规划

  1. 首先是认真审题,结合示例理解。
  2. 题目阐述已经非常清楚了,根据题目意思我们就可以得出我们的动态转移方程。 dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1]
  3. 3.我们最好从[1,1]开始填表,而不是从[0,0]开始,这样可以节省很多边界条件的特判。比较容易控制代码,不容易出错。
  4. 由于这里要求格式化输出,因此我们用c语言的 printf 打印结果是比较方便的。

代码分享

#include <cstdio>
#include <iostream>
using namespace std;
int dp[31][31];

int main()
{
    int n;
    cin >> n;
    dp[1][1] = 1;
    for(int i = 2; i <= n; i++)
    {
        for(int j = 1; j <= i; j++)
        {
            dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1];
        }
    }
    for(int i = 1; i <= n; i++)
    {
        for(int j = 1; j <= i; j++)
        {
            printf("%5d",dp[i][j]);
        }
        printf("\n");
    }
    return 0;
}

总结撒花💞

   本篇文章旨在分享的是题解知识。希望大家通过阅读此文有所收获
   😘如果我写的有什么不好之处,请在文章下方给出你宝贵的意见😊。如果觉得我写的好的话请点个赞赞和关注哦~😘😘😘

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/1922295.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

C++的缺省参数、函数重载和引用

缺省参数 缺省参数是声明或定义函数时为函数的参数指定⼀个缺省值。在调⽤该函数时&#xff0c;如果没有指定实参 则采⽤该形参的缺省值&#xff0c;否则使⽤指定的实参&#xff0c;缺省参数分为全缺省和半缺省参数。(有些地⽅把 缺省参数也叫默认参数)&#xff0c;要注意的是…

相对位移(鼠标)和绝对位移(触摸屏)

引言 EV_REL 表示相对位移(比如鼠标)&#xff0c; EV_ABS 表 示绝对位置(比如触摸屏) 为什么鼠标是相对位移&#xff0c;触摸屏绝对位置? 总结 在Linux操作系统中&#xff0c;输入设备如鼠标和触摸屏通过事件设备接口(Event Device Interface)来与系统交互。这个接口定义了一…

java《字符串基础篇》--字符串全套知识点总结及其配套习题逐语句分析(附带全套源代码)

一、前言 从今天开始就要学习字符串了&#xff0c;java中的字符串和其他编程语言的有些许不同&#xff0c;不过大家也不必担心&#xff0c;基本的原理都是相同的&#xff0c;只是代码的实现有些许差异&#xff0c;问题不大。对于字符串习题方面都是些最基础的题目&#xff0c;…

Matlab结合ChatGPT—如何计算置信区间?

​前面分享了带置信区间的折线图和带置信区间的折线散点图的绘图教程&#xff1a; 很多人表示&#xff0c;昆哥&#xff0c;图是很好看啦&#xff0c;但咱不会求置信区间啊&#xff0c;咋办嘞&#xff1f; 说实话&#xff0c;这种事情属于数据处理&#xff0c;一般都是在画图前…

Hadoop3:HDFS-通过配置黑白名单对集群进行扩缩容,并实现数据均衡(实用)

一、集群情况介绍 我的本地虚拟机&#xff0c;一共有三个节点&#xff0c;hadoop102、hadoop103、hadoop104 二、白名单 创建白名单文件whitelist&#xff0c;通过白名单的配置&#xff0c;只允许集群包含102和103两台机器可以存储数据&#xff0c;104无法存储数据。 需求 …

CSS实现超链接标签:鼠标光标为手形、取消下划线、当鼠标悬停时显示下划线

1、鼠标光标为手形 cursor: pointer; 2、显示/取消下划线 text-decoration: none; /* 文本取消下划线 */ text-decoration: underline; /* 文本添加下划线 */ 3、伪类选择器 伪类选择器是 CSS 中已经定义好的选择器&#xff0c;因此程序员不能随意命令。伪类选择器…

深度学习DeepLearning二元分类 学习笔记

文章目录 类别区分变量与概念逻辑回归Sigmoid函数公式决策边逻辑损失函数和代价函数逻辑回归的梯度下降泛化过拟合的解决方案正则化 类别区分 变量与概念 决策边置信度阈值threshold过拟合欠拟合正则化高偏差lambda&#xff08;λ&#xff09; 线性回归受个别极端值影响&…

ElasticSearch 深度分页详解

原文链接&#xff1a;https://zhuanlan.zhihu.com/p/667036768 1 前言 ElasticSearch 是一个实时的分布式搜索与分析引擎&#xff0c;常用于大量非结构化数据的存储和快速检索场景&#xff0c;具有很强的扩展性。纵使其有诸多优点&#xff0c;在搜索领域远超关系型数据库&…

pycharm 占满磁盘

磁盘里没装什么大文件&#xff0c;发现磁盘被占的越来越满&#xff0c;使用工具查看到底是哪个文件如此之大。 发现罪魁祸首是pycharm&#xff01;&#xff01;&#xff01; 根据工具的提示找到对应的路径文件&#xff1a;E:\pycharm\PyCharmCE2022.3\python_packages 发现pa…

五、 计算机网络(考点篇)

1 网络概述和模型 计算机网络是计算机技术与通信技术相结合的产物&#xff0c;它实现了远程通信、远程信息处理和资源共享。计算机网络的功能&#xff1a;数据通信、资源共享、管理集中化、实现分布式处理、负载均衡。 网络性能指标&#xff1a;速率、带宽(频带宽度或传送线路…

java Web学习笔记(三)

文章目录 1. 前置知识2. Vue使用vite构建项目SFC入门使用ref和.value体会响应式数据&#xff08;使用ES6和setup&#xff09; 3. Vue视图渲染技术及其语法模板语法&#xff1a;命令插值表达式渲染双标><中的文本&#xff08;还挺可爱&#xff09;属性渲染命令事件渲染命令…

php安装Imagick扩展 处理pdf为图片

这个方法是使用源码编译安装&#xff0c;适用于php编译安装和包安装。如果有pecl&#xff0c;直接安装就行&#xff0c;我这是因为多个环境怕直接使用pecl工具导致混乱。 由于浏览器显示大量pdf不方便&#xff0c;我这先将pdf转化为图片再显示 如果没有安装php&#xff0c;这是…

智能家居装修怎么布线?智能家居网络与开关插座布置

打造全屋智能家居。计划的智能家居方案以米家系列为主&#xff0c;智能家居联网方案以无线为主。装修前为了装备智能家居做了很多准备工作&#xff0c;本文深圳侨杰智能分享一个智能家居装修和布线方面的心得与实战知识。希望能对大家的装修有所帮助。 ​1.关于网络 如果房子比…

春招冲刺百题计划|堆

Java基础复习 Java数组的声明与初始化Java ArrayListJava HashMapJava String 类Java LinkedListJava Deque继承LinkedListJava SetJava 队列优先队列:第二题用到了 第一题&#xff1a;215. 数组中的第K个最大元素 可以直接使用Arrays.sort()快排&#xff0c;然后return nums…

数据库第六次

视图 salary decimal(10,2) not null default 0 comment ‘工资’, address varchar(200) not null default ‘’ comment ‘通讯地址’, dept_id int comment ‘部门编号’ ); create index idx_name on emp(emp_name); create index idx_birth on emp(birth); create index…

MySQL-日志-优化

目录 介绍一下mysql 的日志 redo log 和binlog 的区别及应用场景 redo log 和 binlog 在恢复数据库有什么区别? redo log 是怎么实现持久化的? redo log除了崩溃恢复还有什么其他作用? &#xff08;顺序写&#xff09; redo log 怎么刷入磁盘的知道吗&#xff1f; 两阶…

2024西安铁一中集训DAY2 ---- 模拟赛(最小生成树 + AC自动机 + 模拟 + rmq)

文章目录 比赛成绩题解A. 江桥的生成树&#xff08;MST&#xff09;B. 江桥的神秘密码&#xff08;AC自动机&#xff0c;ST表&#xff09;C. 江桥的字符距离D. 江桥的防御力测试&#xff08;rmq&#xff0c;乱搞&#xff09; 比赛成绩 估测&#xff1a;60 100 100 0 260 实…

FastAPI 学习之路(四十九)WebSockets(五)修复接口测试中的问题

其实代码没有问题&#xff0c;但是我们忽略了一个问题&#xff0c;就是在正常的开发中&#xff0c;肯定是遇到过这样的情况&#xff0c;我们频繁的有客户端链接&#xff0c;断开连接&#xff0c;需要统一的管理这些链接&#xff0c;那么应该如何管理呢。其实可以声明一个类去管…

218.贪心算法:分发糖果(力扣)

核心思想 初始化每个学生的糖果数为1&#xff1a; 确保每个学生至少有一颗糖果。从左到右遍历&#xff1a; 如果当前学生的评分高于前一个学生&#xff0c;则当前学生的糖果数应比前一个学生多一颗。从右到左遍历&#xff1a; 如果当前学生的评分高于后一个学生&#xff0c;则…

01对话系统---文字渐出和停顿效果

实现代码 using System.Collections; using System.Collections.Generic; using UnityEngine; using TMPro; using System.Text.RegularExpressions; using System;/// <summary> /// 增加文本时间停顿功能 /// 增加文字渐出&#xff0c;&#xff08;单个字符逐渐显现&a…