12 简单dp学习

cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cmath>
bool dp[100000];
using namespace std;
int n;
int main()
{
	cin >> n;
	int x = 1;
	for (int i = 1;i <= n;i++)
	{
		if (i == 5 || i == 3)
		{
			dp[i] = 1;
		}
		else if(i>5)
		{
			if (dp[i - 5] || dp[i - 3])
			{
				dp[i] = 1;
			}
		}
	}
	if (dp[n])
	{
		for (int i = 0;i <= 2000;i++)
		{
			int t1 = i * 3;
			int t2 = n - i * 3;
			if (t2 % 5 == 0)
			{
				cout << i + (t2 / 5) << endl;
				return 0;
			}
		}
	}
	else
	{
		cout << "-1" << endl;
	}
	return 0;
}
cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cmath>
bool dp[3000010];
using namespace std;
int n;
int main()
{
	cin >> n;
	int ans = 0;
	while (n != 1)
	{
		if (n % 2 == 0)
		{
			n /= 2;
			ans++;
		}
		else
		{
			n--;
			ans++;
		}
	}
	cout << ans << endl;
	return 0;
}
cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cmath>
int dp[1000010];
using namespace std;
int n;
int main()
{
	cin >> n;
	for (int i = 1;i <= n;i++)
	{
		if (i < 5)
		{
			dp[i] = i;
		}
		else if (i < 11)
		{
			dp[i] = min(dp[i - 1], dp[i - 5]) + 1;
		}
		else
		{
			dp[i] = min(dp[i - 1], dp[i - 5]);
			dp[i] = min(dp[i], dp[i - 11] )+1;
		}
	}
	cout << dp[n] << endl;
	return 0;
}
cpp 复制代码
#include<iostream>
using namespace std;
int arr[35][35];
int n, m;
int main()
{
	cin >> n >> m;
	for (int i = 1;i <= n;i++)
	{
		arr[i][1] = 1;
	}
	for (int i = 1;i <= m;i++)
	{
		arr[1][i] = 1;
	}
	for (int i = 2;i <= n;i++)
	{
		for (int j = 2;j <= m;j++)
		{
			if (i % 2 != 0 || j % 2 != 0)
			{
				arr[i][j] = arr[i - 1][j] + arr[i][j - 1];
			}
		}
	}
	cout << arr[n][m];
	return 0;
}
cpp 复制代码
#include<iostream>
#include<algorithm>
#include<cmath>
#include<iomanip>
using namespace std;
int n;
double m[110], d[110];
int day[110];
int main()
{
	cin >> n;
	for (int i = 1;i <= n;i++)
	{
		cin >> day[i];
	}
	m[0] = 100;
	for (int i = 1;i <= n;i++)
	{
		m[i] = max(m[i - 1], d[i - 1] / day[i] * 100);
		d[i] = max(d[i - 1], m[i - 1] * day[i] / 100);
	}
	cout <<fixed<<setprecision(2)<<m[n] << endl;
	return 0;
}
相关推荐
装不满的克莱因瓶2 分钟前
掌握感知器的学习原理
人工智能·python·神经网络·算法·ai·卷积神经网络
Lsk_Smion2 分钟前
力扣实训 _ [994].腐烂的橘子/图论
算法·leetcode·图论
轻微的风格艾丝凡10 分钟前
两电平三相VSC整流模式从不控整流平滑切换至有源整流调试记录
算法·dsp·c2000
雪度娃娃12 分钟前
转向现代C++——保证const成员函数的线程安全性
开发语言·c++
坚果派·白晓明19 分钟前
[鸿蒙PC三方库移植适配] 使用 AtomCode + Skills 自动完成Protobuf鸿蒙化适配
c语言·c++·华为·harmonyos
dongf201924 分钟前
R语言KNN算法
算法·数据分析·r语言
原来是猿32 分钟前
深入理解 C++ unordered_map 与 unordered_set
开发语言·c++
满天星830357734 分钟前
【Qt】信号和槽 (一)(概述和基本使用)
开发语言·c++·qt
努力的章鱼bro37 分钟前
CUDA编程模型
c++·cuda
小O的算法实验室1 小时前
2025年IEEE TASE,基于双层耦合平均场博弈的大规模智能体集成任务分配与轨迹规划
人工智能·算法·机器学习