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;
}
相关推荐
珂朵莉MM几秒前
第七届全球校园人工智能算法精英大赛-算法巅峰赛产业命题赛第3赛季优化题--多策略混合算法
人工智能·算法
罗西的思考7 分钟前
【OpenClaw】通过 Nanobot 源码学习架构---(6)Skills
人工智能·深度学习·算法
枫叶林FYL11 分钟前
【自然语言处理 NLP】7.2 红队测试与对抗鲁棒性(Red Teaming & Adversarial Robustness)
人工智能·算法·机器学习
qiqsevenqiqiqiqi12 分钟前
字符串模板
算法
Fcy64822 分钟前
算法基础详解(六)倍增思想与离散化思想
算法·快速幂·离散化·倍增算法
wuweijianlove36 分钟前
算法调度问题中的代价模型与优化方法的技术5
算法
Dxy123931021641 分钟前
Python路径算法简介
开发语言·python·算法
And_Ii1 小时前
LCR 132.砍竹子Ⅱ
算法
汀、人工智能1 小时前
[特殊字符] 第67课:跳跃游戏II
数据结构·算法·数据库架构·图论·bfs·跳跃游戏ii