博客
关于我
Objective-C实现bellman ford贝尔曼福特算法(附完整源码)
阅读量:796 次
发布时间:2023-02-17

本文共 2072 字,大约阅读时间需要 6 分钟。

Objective-C?????????

????????Bellman-Ford Algorithm?????????????????????????????????????????Objective-C????????????????????????????????????

????

??????????Richard Bellman?????????????DAG?????????????????????????????????????Dijkstra???????????????????????????????????????

????

?Objective-C?????????????????Edge?????????Edge???????????????

#import 
@interface Edge : NSObject @property (nonatomic, assign) NSInteger source; @property (nonatomic, assign) NSInteger destination; @property (nonatomic, assign) NSInteger weight;@end

?????????????????????????????????????

@interface BellmanFord {    NSMutableDictionary *graph;    NSArray *sources;}

????????????????????

BellmanFord *bellman = [[BellmanFord alloc] init];[bellman.graph setValue:[NSMutableArray new] forKey:[NSNumber numberWithInt:1]];NSLog(@"??????");

????

???????????????

  • ??????????
  • ????????????
  • ???????????????
  • ???????

    -(void)bellmanFordAlgorithm{    // ?????????    int n = [self.graph valueForKey:@"???"];    int dist[] = {INF, INF, INF};        // ????    for (int i = 0; i < n; i++) {        for (Edge *edge in [self.graph valueForKey:i+1]) {            int u = edge.source;            int v = edge.destination;            int new_dist = dist[u] + edge.weight;            if (new_dist < dist[v]) {                dist[v] = new_dist;            }        }    }        // ????????    bool updated = true;    while (updated) {        updated = false;        for (int i = 0; i < n; i++) {            for (Edge *edge in [self.graph valueForKey:i+1]) {                int u = edge.source;                int v = edge.destination;                int new_dist = dist[u] + edge.weight;                if (new_dist < dist[v]) {                    dist[v] = new_dist;                    updated = true;                }            }        }    }}

    ????

    ???????????????

  • ???????????????????????
  • ???????????????????????
  • ?????????????????????
  • ????

    ????????????????????????????????????????????????????????

    ??

    ????????????Objective-C????????????????????????????????????????????????????????????????????????

    转载地址:http://cdnfk.baihongyu.com/

    你可能感兴趣的文章
    Objective-C实现logistic regression逻辑回归算法(附完整源码)
    查看>>
    Objective-C实现logistic sigmoid函数(附完整源码)
    查看>>
    Objective-C实现longest Common Substring最长公共子串算法(附完整源码)
    查看>>
    Objective-C实现longest increasing subsequence最长递增子序列算法(附完整源码)
    查看>>
    Objective-C实现longestCommonSubsequence最长公共子序列算法(附完整源码)
    查看>>
    Objective-C实现LongestIncreasingSubsequence最长递增子序列算法(附完整源码)
    查看>>
    Objective-C实现lorenz transformation 洛伦兹变换算法(附完整源码)
    查看>>
    Objective-C实现Lower-Upper Decomposition上下分解算法(附完整源码)
    查看>>
    Objective-C实现LowerCaseConversion小写转换算法(附完整源码)
    查看>>
    Objective-C实现lowest common ancestor最低共同祖先算法(附完整源码)
    查看>>
    Objective-C实现LRU 缓存算法(附完整源码)
    查看>>
    Objective-C实现LRU缓存(附完整源码)
    查看>>
    Objective-C实现LRU(least recently used)算法(附完整源码)
    查看>>
    Objective-C实现lstm prediction预测算法(附完整源码)
    查看>>
    Objective-C实现lucas数列算法(附完整源码)
    查看>>
    Objective-C实现Luhn (Mod 10)Algorithm算法(附完整源码)
    查看>>
    Objective-C实现LZW编码(附完整源码)
    查看>>
    Objective-C实现MAC桌面暗水印(附完整源码)
    查看>>
    Objective-C实现mandelbrot曼德勃罗特集算法(附完整源码)
    查看>>
    Objective-C实现markov chain马尔可夫链算法(附完整源码)
    查看>>