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;
}
相关推荐
_深海凉_3 小时前
LeetCode热题100-寻找两个正序数组的中位数
算法·leetcode·职场和发展
旖-旎4 小时前
深搜练习(电话号码字母组合)(3)
c++·算法·力扣·深度优先遍历
谭欣辰4 小时前
C++快速幂完整实战讲解
算法·决策树·机器学习
Mr_pyx4 小时前
【LeetHOT100】随机链表的复制——Java多解法详解
算法·深度优先
AIFarmer4 小时前
【无标题】
开发语言·c++·算法
AGV算法笔记5 小时前
CVPR 2025 最新感知算法解读:GaussianLSS 如何用 Gaussian Splatting 重构 BEV 表示?
算法·重构·自动驾驶·3d视觉·感知算法·多视角视觉
勤劳的进取家5 小时前
数据链路层基础
网络·学习·算法
Advancer-6 小时前
第二次蓝桥杯总结(上)
java·算法·职场和发展·蓝桥杯
ん贤6 小时前
加密算法(对称、非对称、哈希、签名...)
算法·哈希算法
superior tigre7 小时前
78 子集
算法·leetcode·深度优先·回溯