可能的“船负载”

发布于 2024-09-13 20:43:18 字数 734 浏览 11 评论 0原文

您知道过河问题。这是一个排序描述:

从前,三个食人者正在引导三个传教士穿过丛林。他们正在前往最近的传教站的路上。过了一会儿,他们来到了一条宽阔的河边,河里充满了致命的蛇和鱼。没有船就无法过河。幸运的是,经过短暂的搜寻,他们发现了一艘有两支桨的划艇。不幸的是,船太小,无法承载所有人。它几乎不能同时承载两个人。更糟糕的是,由于河水很宽,除了划回去之外,没有办法把船拉回来。 由于传教士不能相信食人者,他们必须制定一个计划,让他们六个人安全过河。问题是,一旦某个地方的食人者比传教士多,这些食人者就会杀死并吃掉传教士。因此,我们的传教士程序员必须制定一项计划,保证河两岸决不存在少数派传教士。然而,食人者们还是可以相信他们会在其他方面进行合作。具体来说,他们不会放弃任何潜在的食物,就像传教士不会放弃任何潜在的皈依者一样。

我的问题是这个问题的一部分。我正在尝试设计一个返回可能的船载列表的函数(例如,如果 Boat_capacity 为 3,则 [(3mis, 0can), (2mis, 1can), (1mis, 1can), ...] )。我有num(传教士或食人者的数量)和船容量作为我的函数的输入。

你如何设计你的函数和算法?

You know the river-crossing problems. Here is a sort description:

Once upon a time, three cannibals were guiding three missionaries through a jungle. They were on their way to the nearest mission station. After some time, they arrived at a wide river, filled with deadly snakes and fish. There was no way to cross the river without a boat. Fortunately, they found a row boat with two oars after a short search. Unfortunately, the boat was too small to carry all of them. It could barely carry two people at a time. Worse, because of the river's width there was no way to bring the boat back other than to row it back.
Since the missionaries could not trust the cannibals they had to figure out a plan to get all six of them safely across the river. The problem was that these cannibals would kill and eat missionaries as soon as there were more cannibals than missionaries at some place. Thus our missionary-programmer had to devise a plan that guaranteed that there were never any missionaries in the minority at either side of the river. The cannibals, however, can be trusted to cooperate otherwise. Specifically, they won't abandon any potential food, just as the missionaries won't abandon any potential converts.

My question is a part of this problem. I'm trying to design a function which returns list of possible boat-loads (for example if boat_capacity is 3 then [(3mis, 0can), (2mis, 1can), (1mis, 1can), ...]). I have num(number of missionaries or cannibals) and boat-capacity as inputs of my function.

How do you design your function and algorithm?

如果你对这篇内容有疑问,欢迎到本站社区发帖提问 参与讨论,获取更多帮助,或者扫码二维码加入 Web 技术交流群。

扫码二维码加入Web技术交流群

发布评论

需要 登录 才能够评论, 你可以免费 注册 一个本站的账号。

评论(3

夏夜暖风 2024-09-20 20:43:18

以递归方式思考这个问题,也就是说你想从可能的子问题的角度来思考它。因此,如果您有一艘满载三名乘客的船,那么这显然就像一艘只有一名乘客的船,再加上两名乘客的任意组合。

一艘有两名乘客的船有一名乘客加上“一艘满载一名乘客的船”。

所以你的算法基本上看起来像

to find all combinations of n occupants,
    pick an occupant
    if n = 1 return
    if n > 1 find all combinations of (n-1) occupants.

注意这不是精确解决方案,因为这看起来很像一个家庭作业问题。

Think about this in a recursive fashion, which is to say you want to think of it in terms of possible subproblems. So, if you have a boat ful of three occupants, that's obviously like a boat with one occupant, plus any of the combinations of two occupants.

A boat that has two occupants has an occupant plus "a boat full of one occupant".

So your algorithm is going to basically look like

to find all combinations of n occupants,
    pick an occupant
    if n = 1 return
    if n > 1 find all combinations of (n-1) occupants.

Note this isn't the exact solution, as this looks a lot like a homework problem.

玩物 2024-09-20 20:43:18

或者您可以将其视为生成由两个符号组成的所有长度为 1,2 和 3 的字符串。例如,MC。或者,嗯,零和一! 0 代表传教士,1 代表食人者。

010011000111。现在您突然想到“如何”生成它们,对吗?

Or you could think of it instead as generating all strings of length 1,2, and 3 composed of two symbols. Like, for example, M's and C's. Or, hmm, zeroes and ones! 0 for missionaries and 1 for cannibals.

0 to 1, 00 to 11, and 000 to 111. The 'how' of generating them just jumps out at you now, right?

帅气尐潴 2024-09-20 20:43:18

我在Scheme环境下解决了这个问题。也许它不是很快,但它确实有效。

;;; boat-loads : mc_num  boat_capacity --> list of boat_loads 
;;; returns a list of possible (cannibals cannot be more than missionaries)
;;; boat-loads

(define (boat-loads mc bc storage)
 (local 
  ((define isBoatBig (> bc mc))
   (define (both  mc bc storage)
     (cond 
         [(< mc 1) storage]
         [else 
          (both (- mc 1) bc (append storage (list (list mc (- bc mc)))))]))
   (define (single mc bc storage)
    (cond 
      [(= mc 0) storage]
      [else 
       (single (- mc 1) bc (append storage (list (list mc 0) (list 0 mc))))]))
  (define (filt l)
    (local
      ((define (filter-equal l acc)
         (local 
           ((define (filter-equal-inner f  l)
              (cond 
                [(empty? l) (list f)]
                [(equal? f (first l))  (filter-equal-inner (first l) (rest l))]
                [else (append (list (first l))
                              (filter-equal-inner f (rest l)))]))
            (define done (filter-equal-inner (first l) (rest l))))
           (cond 
             [(= 0 acc) done]
             [else (filter-equal done (- acc 1))]))))
       (filter-equal l (length l)))))
  (cond
   [(= bc 0) storage]
   [else 
    (filt (boat-loads mc
                      (- bc 1)
                      (append storage
                              (if isBoatBig 
                                  (filter (lambda (x)
                                            (if (>= (first x) (second x))
                                                true false))
                                          (append (both mc bc empty)
                                                  (single mc bc empty)))
                                  (filter (lambda (x)
                                            (if (>= (first x) (second x))
                                                true false))
                                          (append (both bc bc empty)
                                                  (single bc bc empty)))))))])))

I solved the problem in a Scheme environment. Probably it is not very fast, but it works.

;;; boat-loads : mc_num  boat_capacity --> list of boat_loads 
;;; returns a list of possible (cannibals cannot be more than missionaries)
;;; boat-loads

(define (boat-loads mc bc storage)
 (local 
  ((define isBoatBig (> bc mc))
   (define (both  mc bc storage)
     (cond 
         [(< mc 1) storage]
         [else 
          (both (- mc 1) bc (append storage (list (list mc (- bc mc)))))]))
   (define (single mc bc storage)
    (cond 
      [(= mc 0) storage]
      [else 
       (single (- mc 1) bc (append storage (list (list mc 0) (list 0 mc))))]))
  (define (filt l)
    (local
      ((define (filter-equal l acc)
         (local 
           ((define (filter-equal-inner f  l)
              (cond 
                [(empty? l) (list f)]
                [(equal? f (first l))  (filter-equal-inner (first l) (rest l))]
                [else (append (list (first l))
                              (filter-equal-inner f (rest l)))]))
            (define done (filter-equal-inner (first l) (rest l))))
           (cond 
             [(= 0 acc) done]
             [else (filter-equal done (- acc 1))]))))
       (filter-equal l (length l)))))
  (cond
   [(= bc 0) storage]
   [else 
    (filt (boat-loads mc
                      (- bc 1)
                      (append storage
                              (if isBoatBig 
                                  (filter (lambda (x)
                                            (if (>= (first x) (second x))
                                                true false))
                                          (append (both mc bc empty)
                                                  (single mc bc empty)))
                                  (filter (lambda (x)
                                            (if (>= (first x) (second x))
                                                true false))
                                          (append (both bc bc empty)
                                                  (single bc bc empty)))))))])))
~没有更多了~
我们使用 Cookies 和其他技术来定制您的体验包括您的登录状态等。通过阅读我们的 隐私政策 了解更多相关信息。 单击 接受 或继续使用网站,即表示您同意使用 Cookies 和您的相关数据。
原文