noi-11月30日当堂练习

**题目:**P1294 高手去散步

网址: https://www.luogu.com.cn/problem/P1294

**思路:**按照题目意思模拟

**知识点:**dfs

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define eb emplace_back
#define pii pair<int,int>
#define fi first
#define se second
using namespace std;

int a[110][100];
int ans,n,m;
int vis[110];
void dfs(int step,int last,int s)
{
	ans=max(ans,s); 
	for(int i=1;i<=n;i++)
	{
		if(!vis[i]&&a[last][i]!=-1)
		{
			vis[i]=true;
			dfs(step+1,i,s+a[last][i]);
			vis[i]=false;
		}
	}
}
int main(){
		
	
	cin>>n>>m;
	for(int i=1;i<=n;i++)
	{
	  for(int j=1;j<=n;j++)
	  a[i][j]=-1;	
	} 
	for(int i=1;i<=m;i++)
	{
	   int x,y,len;
	   cin>>x>>y>>len;
	   a[x][y]=len;
	   a[y][x]=len;	
	} 

	dfs(1,0,0);
	cout<<ans; 
	return 0;
}

**题目:**P1706 全排列问题

网址: https://www.luogu.com.cn/problem/P1706

**思路:**按照题目意思模拟

**知识点:**dfs

代码:

cpp 复制代码
#include<bits/stdc++.h>
#define ll long long
#define eb emplace_back
#define pii pair<int,int>
#define fi first
#define se second
using namespace std;

int a[100]; 
int vis[100];
int n; 
void dfs(int step)
{
	if(step>n)
	{
		for(int i=1;i<=n;i++)
		{
			
			cout<<"    ";
			cout<<a[i];
		}
		cout<<'\n';
		return;
	}
	for(int i=1;i<=n;i++)
	{
		if(!vis[i])
		{
			vis[i]=true;
			a[step]=i;
			dfs(step+1);
			vis[i]=false;
		}
	}
}
int main(){
		
	cin>>n;
	dfs(1);
	return 0;
}
相关推荐
绿算技术20 小时前
万卡推理集群存储选型分析:从核心架构到应用视角
大数据·科技·算法·架构
想吃火锅100521 小时前
【leetcode】1.两数之和js版
javascript·算法·leetcode
net3m331 天前
一阶软件低通滤波器算法
人工智能·算法
水木流年追梦1 天前
大模型入门-大模型优化方法12-YaRN 长文本外推技术
人工智能·分布式·算法·正则表达式·prompt
J-Tony111 天前
【JVM】三色标记法
java·jvm·算法
wengad1 天前
机器学习实践理论基础|算法、模型和数据集
人工智能·算法·机器学习
梦梦代码精1 天前
为什么这个开源的AI平台会火?有点东西。。。
人工智能·算法·机器学习·docker·开源
随意起个昵称1 天前
线性dp-综合刷题1(Not Alone)
算法·动态规划
如何原谅奋力过但无声1 天前
【灵神高频面试题合集09-13】二叉树、二叉搜索树
数据结构·算法·leetcode