Clojure 2024状态调查!中分享您的想法。

欢迎!请访问关于页面以获取更多有关其工作方式的详细信息。

0
语法和读取器
(defn get-pins [observed]
  (let [num (count observed)
        keypad {\1 [1 2 4] \2 [2 1 5 3] \3 [3 2 6]
                \4 [4 1 5 7] \5 [5 2 6 8 4] \6 [6 3 5 9]
                \7 [7 4 8] \8 [8 5 9 0 7] \9 [9 6 8] \0 [0 8]}
        observed-map (zipmap [:a :b :c :d] (map keypad observed))]
    (case num
      1 (for [a (:a observed-map)]
          (str a))
      2 (for [a (:a observed-map)
              b (:b observed-map)]
         (str a b))
      3 (for [a (:a observed-map)
              b (:b observed-map)
              c (:c observed-map)]
         (str a b c))
      4 (for [a (:a observed-map)
              b (:b observed-map)
              c (:c observed-map)
              d (:d observed-map)]
         (str a b c d))
       "default")))

2 个答案

+1

以下操作将完成您想要的:

(defn get-pins [observed]
  (let [num (count observed)
        keypad {\1 [1 2 4] \2 [2 1 5 3] \3 [3 2 6]
                \4 [4 1 5 7] \5 [5 2 6 8 4] \6 [6 3 5 9]
                \7 [7 4 8] \8 [8 5 9 0 7] \9 [9 6 8] \0 [0 8]}
        observed-map (zipmap [:a :b :c :d] (map keypad observed))]
    (for [a (:a observed-map) 
          b (or (:b observed-map) [nil]) 
          c (or (:c observed-map) [nil]) 
          d (or (:d observed-map) [nil])] 
      (str a b c d))))

[nil]值将导致单个“迭代”(带有值nil),并在对它调用str时生成空字符串。

感谢帮助
0

您在这里提出了什么问题?能进一步说明吗?

能否将case语句改为更灵活的解决方案,比如使用单行for语句,同时使其仍然适用于各种长度的字符串。
不,`for` 并不适合这个。
...