【day04】Fibonacci数列 | 单词搜索 | 杨辉三角

1.Fibonacci数列

题目链接: Fibonacci数列_牛客题霸_牛客网

解题思路:

求斐波那契数列的过程中,判断⼀下:何时n会在两个fib数之间。

复制代码
#include <bits/stdc++.h>

using namespace std;

#define int long long

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

2.单词搜索

题目链接: 单词搜索_牛客题霸_牛客网

解题思路:简单的深度搜索题(dfs)

复制代码
class Solution
{
    int n, m;
    bool vis[101][101] = {0};
    int dx[4] = {0, 0, 1, -1};
    int dy[4] = {1, -1, 0, 0};

public:
    bool exist(vector<string> &board, string word)
    {
        m = board.size(), n = board[0].size();
        for (int i = 0; i < m; i++)
        {
            for (int j = 0; j < n; j++)
            {
                if (board[i][j] == word[0])
                {
                    if (dfs(board, i, j, word, 0))
                        return true;
                }
            }
        }
        return false;
    }

    bool dfs(vector<string> &board, int i, int j, string &word, int pos)
    {
        if (pos == word.size() - 1)
            return true;

        vis[i][j] = true;
        for (int k = 0; k < 4; k++)
        {
            int a = i + dx[k], b = dy[k] + j;
            if (a >= 0 && a < m && b >= 0 && b < n && !vis[a][b] && board[a][b] == word[pos + 1])
            {
                if (dfs(board, a, b, word, pos + 1))
                    return true;
            }
        }
        vis[i][j] = false;
        return false;
    }
};

3.杨辉三角

题目链接:

杨辉三角_牛客题霸_牛客网

解题思路:最基础的dp模型,按照规律模拟出来杨辉三⻆即可。

复制代码
#include <bits/stdc++.h>

using namespace std;

#define int long long

int dp[31][31];
signed main()
{
    int n;
    cin >> n;
    dp[1][1] = 1;
    for(int i = 2;i <= n;i ++)
    {
        for(int j = 1;j <= n;j ++)
        {
            dp[i][j] = dp[i - 1][j] + dp[i][j - 1];
        }
    }

    for(int i = 1;i <= n;i ++)
    {
        for(int j = 1;j <= n;j ++)
        {
            printf("%5d", dp[i][j]);
        }
        printf("\n");
    }
    return 0;
}
相关推荐
啊阿狸不会拉杆31 分钟前
《算法导论》第 32 章 - 字符串匹配
开发语言·c++·算法
小学生的信奥之路1 小时前
洛谷P3817题解:贪心算法解决糖果分配问题
c++·算法·贪心算法
你知道网上冲浪吗2 小时前
【原创理论】Stochastic Coupled Dyadic System (SCDS):一个用于两性关系动力学建模的随机耦合系统框架
python·算法·数学建模·数值分析
地平线开发者3 小时前
征程 6 | PTQ 精度调优辅助代码,总有你用得上的
算法·自动驾驶
Tisfy4 小时前
LeetCode 837.新 21 点:动态规划+滑动窗口
数学·算法·leetcode·动态规划·dp·滑动窗口·概率
CoovallyAIHub4 小时前
为高空安全上双保险!无人机AI护航,YOLOv5秒判安全带,守护施工生命线
深度学习·算法·计算机视觉
huangzixuan10074 小时前
08.18总结
算法·深度优先·图论
逆向菜鸟4 小时前
【摧毁比特币】椭圆曲线象限细分求k-陈墨仙
python·算法
DolphinDB5 小时前
DolphinDB 回测插件快速上手
算法
利刃大大5 小时前
【动态规划:路径问题】最小路径和 && 地下城游戏
算法·动态规划·cpp·路径问题