【强训笔记】day4

NO.1

思路:利用滚动数组,迭代一个Fibonacci数列,给出三个值进行循环迭代,当n<c时,说明n在b和c之间,这里只需要返回c-n和n-b的最小值就可以了。

代码实现:

cpp 复制代码
#include<iostream>

using namespace std;

int 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;
}

NO.2

代码实现:

cpp 复制代码
class Solution
{
	int m, n;
	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 = j + dy[k];
			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;
	}
};

NO.3

思路:dp线性数组,dp[1][1]=1,在根据状态方程dp[i][j] = dp[i - 1][j] + dp[i - 1][j - 1]进行求解。

cpp 复制代码
#include<iostream>

using namespace std;
int dp[31][31];
int n;
int main()
{
	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;
}
相关推荐
仰泳的熊猫42 分钟前
题目1453:蓝桥杯历届试题-翻硬币
数据结构·c++·算法·蓝桥杯
唐梓航-求职中42 分钟前
技术-算法-leetcode-1606. 找到处理最多请求的服务器(易懂版)
服务器·算法·leetcode
啊阿狸不会拉杆43 分钟前
《机器学习导论》第 10 章-线性判别式
人工智能·python·算法·机器学习·numpy·lda·线性判别式
BlackWolfSky44 分钟前
鸿蒙高级课程笔记2—应用性能优化
笔记·华为·harmonyos
会叫的恐龙44 分钟前
C++ 核心知识点汇总(第11日)(排序算法)
c++·算法·排序算法
twilight_46944 分钟前
机器学习与模式识别——线性回归算法
算法·机器学习·线性回归
玄同7651 小时前
Python Random 模块深度解析:从基础 API 到 AI / 大模型工程化实践
人工智能·笔记·python·学习·算法·语言模型·llm
Pluchon1 小时前
硅基计划4.0 算法 简单模拟实现位图&布隆过滤器
java·大数据·开发语言·数据结构·算法·哈希算法
符哥20081 小时前
C++ 适合初学者的学习笔记整理
c++·笔记·学习
独断万古他化1 小时前
【算法通关】前缀和:和为 K、和被 K整除、连续数组、矩阵区域和全解
算法·前缀和·矩阵·哈希表