【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;
}
相关推荐
小O的算法实验室2 小时前
2025年IEEE TETCI,异构无人机取送货问题中的转运优化,深度解析+性能实测
算法·论文复现·智能算法·智能算法改进
chao1898448 小时前
基于 SPEA2 的多目标优化算法 MATLAB 实现
开发语言·算法·matlab
沪漂阿龙8 小时前
AI大模型面试题:支持向量机是什么?间隔最大化、软间隔、核函数、LinearSVC 全面拆解
人工智能·算法·支持向量机
little~钰9 小时前
倍增算法和ST表
算法
知识领航员10 小时前
蘑兔AI音乐深度实测:功能拆解、实测表现与适用场景
java·c语言·c++·人工智能·python·算法·github
薛定e的猫咪10 小时前
因果推理研究方向综述笔记
人工智能·笔记·深度学习·算法
如何原谅奋力过但无声11 小时前
【灵神高频面试题合集06-08】反转链表、快慢指针(环形链表/重排链表)、前后指针(删除链表/链表去重)
数据结构·python·算法·leetcode·链表
平行侠11 小时前
037插入排序 - 整理扑克牌的算法
数据结构·算法
ECT-OS-JiuHuaShan11 小时前
彻底定理化:从量子纠缠到量子代谢
数据库·人工智能·学习·算法·生活·量子计算