0

0

计算所有整数的排列,这些排列可以根据给定的条件形成一个无环图

WBOY

WBOY

发布时间:2023-09-07 11:37:02

|

994人浏览过

|

来源于tutorialspoint

转载

计算所有整数的排列,这些排列可以根据给定的条件形成一个无环图

对于整数N以内的阶段进行计数,形成非循环图需要对每一个可能的变化进行调查,并检查它们是否根据给定条件形成非循环图。这些条件可能与由变化形成的协调图结构相关,其中循环的缺失表示非循环性。这个问题涉及图论的概念,并可以通过深度优先搜索或动态规划来解决。深度优先搜索通过递归地调查每个阶段,动态规划通过存储中间结果来优化循环。最后计数的有效阶段数显示了整数N以内可以组织成满足预定条件的非循环图的方式数

使用的方法

  • 深度优先搜索 (DFS)

  • 动态规划

深度优先搜索(DFS)

在生成具有给定操作的分组的DFS方法中,我们从给定的数字开始,通过重新计算直到达到值1。我们按照以下方式继续进行:如果数字确实为2,则将其除以2;如果是奇数,则将其乘以3并加1。我们更新数字以反映未使用的结果,并将其添加到序列中。这个过程持续到数字达到1。所得到的序列表示给定起始数字的重复Collatz序列。这种方法允许我们跟踪数字通过重复计算而发生变化的进展,揭示模式,并考虑Collatz序列的行为。它提供了一种简单且可重复的方法来生成序列,并分析这一数学奇迹的迷人特征。

算法

  • 选择一个起始枢纽来开始穿越

  • 将中心标记为已访问,以监控哪些中心已经主动进行了调查。

  • 访问正在进行的中心节点的未访问邻居(如果有)。要确定正在进行的中心节点的邻居,您确实需要了解图的传染性描述(例如,接近度列表或接近度框架)

  • 假设存在未访问的邻居,选择其中一个并从该邻居重新进行第2到第4阶段的重新散列(递归地)

  • 假设没有未访问的邻居,回溯到过去的中心,并从那个点继续进行调查(如果可能的话)。这一步对于探索图中所有潜在路径至关重要

  • 重新进行2到5阶段的哈希,直到图表中的所有中心节点都被访问。如果图表未连接(包含多个部分),您可能需要从未访问的中心节点开始进行深度优先搜索(DFS)。

Example

的中文翻译为:

示例

#include 
#include 

using namespace std;

void dfs(int node, vector>& graph, vector& visited) {
   visited[node] = true;
   cout << "Visited hub: " << node << endl;
   for (int neighbor : graph[node]) {
      if (!visited[neighbor]) {
         cout << "Moving to neighbor: " << neighbor << endl;
         dfs(neighbor, graph, visited);
      }
   }
}

int main() {
   vector> graph = {
      {1, 2},
      {0, 2, 3},
      {0, 1, 3},
      {1, 2, 4},
      {3}
   };
   int hubs = graph.size();
   vector visited(hubs, false);
   int startingHub = 0;
   cout << "DFS Traversal starting from hub " << startingHub << ":" << endl;
   dfs(startingHub, graph, visited);
   return 0;
}

输出

DFS Traversal starting from hub 0:
Visited hub: 0
Moving to neighbor: 1
Visited hub: 1
Moving to neighbor: 2
Visited hub: 2
Moving to neighbor: 3
Visited hub: 3
Moving to neighbor: 4
Visited hub: 4

动态规划

在这种方法中,我们可以利用动态规划来有效地计算到达N的非循环阶段的数量。我们将定义一个DP表,其中dp[i]表示以数字I结尾的非循环转换的数量。

算法

  • 调查问题并决定是否可以将其分解为较小的子问题。如果多次解决相同的子问题是低效的,动态规划可以通过记住子问题的解决方案来改善解决方案。

    白果AI论文
    白果AI论文

    论文AI生成学术工具,真实文献,免费不限次生成论文大纲 10 秒生成逻辑框架,10 分钟产出初稿,智能适配 80+学科。支持嵌入图表公式与合规文献引用

    下载
  • 将一个更大问题的安排表达为其子问题的安排。这种重复连接是使用DP解决问题的关键。

  • 鉴于重复的连接,制作一个表格或展示来存储子问题的答案。这将防止重复计算。

  • 从最小的子问题开始填写表格,通常采用自底向上的方式,或者使用记忆化来在递归过程中存储和检索解决方案

  • 当所有子问题都解决完毕时,将最后的排列从DP表或记忆化展示中分离出来。

Example

的中文翻译为:

示例

#include 
#include 
using namespace std;

int knapsackHelper(vector>& dp, vector& weights, vector& values, int n, int capacity) {
   if (n == 0 || capacity == 0) {
      return 0;
   }

   if (dp[n][capacity] != -1) {
      return dp[n][capacity];
   }

   if (weights[n - 1] <= capacity) {
      dp[n][capacity] = max(values[n - 1] + knapsackHelper(dp, weights, values, n - 1, capacity - weights[n - 1]),
                      knapsackHelper(dp, weights, values, n - 1, capacity));
   } else {
      dp[n][capacity] = knapsackHelper(dp, weights, values, n - 1, capacity);
   }

   return dp[n][capacity];
}

int knapsack(vector& weights, vector& values, int capacity) {
   int n = weights.size();
   vector> dp(n + 1, vector(capacity + 1, -1));
   return knapsackHelper(dp, weights, values, n, capacity);
}

int main() {
   vector weights = {10, 20, 30};
   vector values = {60, 100, 120};
   int capacity = 50;
   cout << "Maximum value in Knapsack: " << knapsack(weights, values, capacity) << endl;
   return 0;
}

输出

Maximum value in Knapsack: 220

结论

计算可以形成非循环图的阶段包括研究整数的不同排列方式,以确保它们满足给定的条件。DFS递归地探索阶段,而DP通过记忆化改进循环。这两种方法提供了解决这个问题的重要方法。方法的选择取决于限制条件和N的大小。通过这些方法,我们可以高效地找到合法阶段的数量,帮助我们理解数字可以按照预定条件形成非循环图的方式。

相关专题

更多
页面置换算法
页面置换算法

页面置换算法是操作系统中用来决定在内存中哪些页面应该被换出以便为新的页面提供空间的算法。本专题为大家提供页面置换算法的相关文章,大家可以免费体验。

403

2023.08.14

Java JVM 原理与性能调优实战
Java JVM 原理与性能调优实战

本专题系统讲解 Java 虚拟机(JVM)的核心工作原理与性能调优方法,包括 JVM 内存结构、对象创建与回收流程、垃圾回收器(Serial、CMS、G1、ZGC)对比分析、常见内存泄漏与性能瓶颈排查,以及 JVM 参数调优与监控工具(jstat、jmap、jvisualvm)的实战使用。通过真实案例,帮助学习者掌握 Java 应用在生产环境中的性能分析与优化能力。

6

2026.01.20

PS使用蒙版相关教程
PS使用蒙版相关教程

本专题整合了ps使用蒙版相关教程,阅读专题下面的文章了解更多详细内容。

59

2026.01.19

java用途介绍
java用途介绍

本专题整合了java用途功能相关介绍,阅读专题下面的文章了解更多详细内容。

80

2026.01.19

java输出数组相关教程
java输出数组相关教程

本专题整合了java输出数组相关教程,阅读专题下面的文章了解更多详细内容。

37

2026.01.19

java接口相关教程
java接口相关教程

本专题整合了java接口相关内容,阅读专题下面的文章了解更多详细内容。

10

2026.01.19

xml格式相关教程
xml格式相关教程

本专题整合了xml格式相关教程汇总,阅读专题下面的文章了解更多详细内容。

13

2026.01.19

PHP WebSocket 实时通信开发
PHP WebSocket 实时通信开发

本专题系统讲解 PHP 在实时通信与长连接场景中的应用实践,涵盖 WebSocket 协议原理、服务端连接管理、消息推送机制、心跳检测、断线重连以及与前端的实时交互实现。通过聊天系统、实时通知等案例,帮助开发者掌握 使用 PHP 构建实时通信与推送服务的完整开发流程,适用于即时消息与高互动性应用场景。

17

2026.01.19

微信聊天记录删除恢复导出教程汇总
微信聊天记录删除恢复导出教程汇总

本专题整合了微信聊天记录相关教程大全,阅读专题下面的文章了解更多详细内容。

155

2026.01.18

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
PostgreSQL 教程
PostgreSQL 教程

共48课时 | 7.5万人学习

Django 教程
Django 教程

共28课时 | 3.3万人学习

Excel 教程
Excel 教程

共162课时 | 12.5万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号