check for pangrams in elispMinor mode for blog writing in HTMLA small emacs-lisp snippet for opening a register in another windowIs using defvar for a non-global variable ok?Emacs module that generates templates for my blog's static site generatorAccessor functions in elispX-up utility for EVE OnlineTesting whether lambda expression returns true for any list elementRubik's cube mode for emacsStoring facts for logical questionsGet the suffix for the date string

I see my dog run

How is it possible for user's password to be changed after storage was encrypted? (on OS X, Android)

Should I join office cleaning event for free?

What is the offset in a seaplane's hull?

What defenses are there against being summoned by the Gate spell?

Download, install and reboot computer at night if needed

Work Breakdown with Tikz

A newer friend of my brother's gave him a load of baseball cards that are supposedly extremely valuable. Is this a scam?

What do you call something that goes against the spirit of the law, but is legal when interpreting the law to the letter?

Is there really no realistic way for a skeleton monster to move around without magic?

Why are 150k or 200k jobs considered good when there are 300k+ births a month?

GPS Rollover on Android Smartphones

How can I fix this gap between bookcases I made?

Why CLRS example on residual networks does not follows its formula?

What makes Graph invariants so useful/important?

Why is the design of haulage companies so “special”?

Email Account under attack (really) - anything I can do?

What are these boxed doors outside store fronts in New York?

Shell script can be run only with sh command

Banach space and Hilbert space topology

How much RAM could one put in a typical 80386 setup?

How is it possible to have an ability score that is less than 3?

How to make payment on the internet without leaving a money trail?

How did the USSR manage to innovate in an environment characterized by government censorship and high bureaucracy?



check for pangrams in elisp


Minor mode for blog writing in HTMLA small emacs-lisp snippet for opening a register in another windowIs using defvar for a non-global variable ok?Emacs module that generates templates for my blog's static site generatorAccessor functions in elispX-up utility for EVE OnlineTesting whether lambda expression returns true for any list elementRubik's cube mode for emacsStoring facts for logical questionsGet the suffix for the date string






.everyoneloves__top-leaderboard:empty,.everyoneloves__mid-leaderboard:empty,.everyoneloves__bot-mid-leaderboard:empty margin-bottom:0;








0












$begingroup$


I'm trying to find pangrams ie sentences that contain all the letters of the alphabet, for instance "The quick brown fox jumps over the lazy dog".



I'm an absolute beginner in elisp, and it ended up being a really difficult exercice for me. My idea what to put all the letters in a set check if all the letters of the alphabet are in this set.



I don't think it was a very good idea because elisp doesn't seem to really have sets, so I ended up using a hashmap, which seems very clunky.



Another things that really bothers me is the two if in is-pangram. I feel that they make the function really difficult to reason about, although it's doing something very basic.



(defun add-to-hashmap (hashmap item)
"Insert ITEM into HASHMAP and return HASHMAP."
(puthash item t hashmap)
hashmap)

(defun iter-hashmap-keys (hashmap)
"Return a sequence of the keys in HASHMAP"
(let ((keys '()))
(maphash
(lambda (key _) (setq keys (cons key keys)))
hashmap)
keys))

(defun get-letters (s)
"Return the set of letters in S.
The set is a hashmap where keys are ascii characters and values are `t`."
(setq letters (make-hash-table :test 'equal))
(seq-reduce
(lambda (hashmap letter) (add-to-hashmap hashmap (downcase letter)))
(split-string s "")
letters))

(defvar ALPHABET
(let* ((letters (get-letters "abcdefghijklmnopqrstuvwxyz"))
(_ (remhash "" letters)))
letters))

(defun is-pangram (s)
"Return `t` is S is a pangram, `nil` otherwise."
(setq letters (get-letters s))
(if (seq-some
;; this function returns returns `nil` if the given letter is
;; *present* in the set, and `t` otherwise. That way, seq-some
;; returns a non-nil value when there's a letter that is *not* in
;; the set.
(lambda (letter) (if (gethash letter letters) nil t))
(iter-hashmap-keys ALPHABET))
nil
t))

(provide 'pangram)
```








share









$endgroup$


















    0












    $begingroup$


    I'm trying to find pangrams ie sentences that contain all the letters of the alphabet, for instance "The quick brown fox jumps over the lazy dog".



    I'm an absolute beginner in elisp, and it ended up being a really difficult exercice for me. My idea what to put all the letters in a set check if all the letters of the alphabet are in this set.



    I don't think it was a very good idea because elisp doesn't seem to really have sets, so I ended up using a hashmap, which seems very clunky.



    Another things that really bothers me is the two if in is-pangram. I feel that they make the function really difficult to reason about, although it's doing something very basic.



    (defun add-to-hashmap (hashmap item)
    "Insert ITEM into HASHMAP and return HASHMAP."
    (puthash item t hashmap)
    hashmap)

    (defun iter-hashmap-keys (hashmap)
    "Return a sequence of the keys in HASHMAP"
    (let ((keys '()))
    (maphash
    (lambda (key _) (setq keys (cons key keys)))
    hashmap)
    keys))

    (defun get-letters (s)
    "Return the set of letters in S.
    The set is a hashmap where keys are ascii characters and values are `t`."
    (setq letters (make-hash-table :test 'equal))
    (seq-reduce
    (lambda (hashmap letter) (add-to-hashmap hashmap (downcase letter)))
    (split-string s "")
    letters))

    (defvar ALPHABET
    (let* ((letters (get-letters "abcdefghijklmnopqrstuvwxyz"))
    (_ (remhash "" letters)))
    letters))

    (defun is-pangram (s)
    "Return `t` is S is a pangram, `nil` otherwise."
    (setq letters (get-letters s))
    (if (seq-some
    ;; this function returns returns `nil` if the given letter is
    ;; *present* in the set, and `t` otherwise. That way, seq-some
    ;; returns a non-nil value when there's a letter that is *not* in
    ;; the set.
    (lambda (letter) (if (gethash letter letters) nil t))
    (iter-hashmap-keys ALPHABET))
    nil
    t))

    (provide 'pangram)
    ```








    share









    $endgroup$














      0












      0








      0





      $begingroup$


      I'm trying to find pangrams ie sentences that contain all the letters of the alphabet, for instance "The quick brown fox jumps over the lazy dog".



      I'm an absolute beginner in elisp, and it ended up being a really difficult exercice for me. My idea what to put all the letters in a set check if all the letters of the alphabet are in this set.



      I don't think it was a very good idea because elisp doesn't seem to really have sets, so I ended up using a hashmap, which seems very clunky.



      Another things that really bothers me is the two if in is-pangram. I feel that they make the function really difficult to reason about, although it's doing something very basic.



      (defun add-to-hashmap (hashmap item)
      "Insert ITEM into HASHMAP and return HASHMAP."
      (puthash item t hashmap)
      hashmap)

      (defun iter-hashmap-keys (hashmap)
      "Return a sequence of the keys in HASHMAP"
      (let ((keys '()))
      (maphash
      (lambda (key _) (setq keys (cons key keys)))
      hashmap)
      keys))

      (defun get-letters (s)
      "Return the set of letters in S.
      The set is a hashmap where keys are ascii characters and values are `t`."
      (setq letters (make-hash-table :test 'equal))
      (seq-reduce
      (lambda (hashmap letter) (add-to-hashmap hashmap (downcase letter)))
      (split-string s "")
      letters))

      (defvar ALPHABET
      (let* ((letters (get-letters "abcdefghijklmnopqrstuvwxyz"))
      (_ (remhash "" letters)))
      letters))

      (defun is-pangram (s)
      "Return `t` is S is a pangram, `nil` otherwise."
      (setq letters (get-letters s))
      (if (seq-some
      ;; this function returns returns `nil` if the given letter is
      ;; *present* in the set, and `t` otherwise. That way, seq-some
      ;; returns a non-nil value when there's a letter that is *not* in
      ;; the set.
      (lambda (letter) (if (gethash letter letters) nil t))
      (iter-hashmap-keys ALPHABET))
      nil
      t))

      (provide 'pangram)
      ```








      share









      $endgroup$




      I'm trying to find pangrams ie sentences that contain all the letters of the alphabet, for instance "The quick brown fox jumps over the lazy dog".



      I'm an absolute beginner in elisp, and it ended up being a really difficult exercice for me. My idea what to put all the letters in a set check if all the letters of the alphabet are in this set.



      I don't think it was a very good idea because elisp doesn't seem to really have sets, so I ended up using a hashmap, which seems very clunky.



      Another things that really bothers me is the two if in is-pangram. I feel that they make the function really difficult to reason about, although it's doing something very basic.



      (defun add-to-hashmap (hashmap item)
      "Insert ITEM into HASHMAP and return HASHMAP."
      (puthash item t hashmap)
      hashmap)

      (defun iter-hashmap-keys (hashmap)
      "Return a sequence of the keys in HASHMAP"
      (let ((keys '()))
      (maphash
      (lambda (key _) (setq keys (cons key keys)))
      hashmap)
      keys))

      (defun get-letters (s)
      "Return the set of letters in S.
      The set is a hashmap where keys are ascii characters and values are `t`."
      (setq letters (make-hash-table :test 'equal))
      (seq-reduce
      (lambda (hashmap letter) (add-to-hashmap hashmap (downcase letter)))
      (split-string s "")
      letters))

      (defvar ALPHABET
      (let* ((letters (get-letters "abcdefghijklmnopqrstuvwxyz"))
      (_ (remhash "" letters)))
      letters))

      (defun is-pangram (s)
      "Return `t` is S is a pangram, `nil` otherwise."
      (setq letters (get-letters s))
      (if (seq-some
      ;; this function returns returns `nil` if the given letter is
      ;; *present* in the set, and `t` otherwise. That way, seq-some
      ;; returns a non-nil value when there's a letter that is *not* in
      ;; the set.
      (lambda (letter) (if (gethash letter letters) nil t))
      (iter-hashmap-keys ALPHABET))
      nil
      t))

      (provide 'pangram)
      ```






      lisp elisp





      share












      share










      share



      share










      asked 7 mins ago









      little-dudelittle-dude

      22516




      22516




















          0






          active

          oldest

          votes












          Your Answer





          StackExchange.ifUsing("editor", function ()
          return StackExchange.using("mathjaxEditing", function ()
          StackExchange.MarkdownEditor.creationCallbacks.add(function (editor, postfix)
          StackExchange.mathjaxEditing.prepareWmdForMathJax(editor, postfix, [["\$", "\$"]]);
          );
          );
          , "mathjax-editing");

          StackExchange.ifUsing("editor", function ()
          StackExchange.using("externalEditor", function ()
          StackExchange.using("snippets", function ()
          StackExchange.snippets.init();
          );
          );
          , "code-snippets");

          StackExchange.ready(function()
          var channelOptions =
          tags: "".split(" "),
          id: "196"
          ;
          initTagRenderer("".split(" "), "".split(" "), channelOptions);

          StackExchange.using("externalEditor", function()
          // Have to fire editor after snippets, if snippets enabled
          if (StackExchange.settings.snippets.snippetsEnabled)
          StackExchange.using("snippets", function()
          createEditor();
          );

          else
          createEditor();

          );

          function createEditor()
          StackExchange.prepareEditor(
          heartbeatType: 'answer',
          autoActivateHeartbeat: false,
          convertImagesToLinks: false,
          noModals: true,
          showLowRepImageUploadWarning: true,
          reputationToPostImages: null,
          bindNavPrevention: true,
          postfix: "",
          imageUploader:
          brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
          contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
          allowUrls: true
          ,
          onDemand: true,
          discardSelector: ".discard-answer"
          ,immediatelyShowMarkdownHelp:true
          );



          );













          draft saved

          draft discarded


















          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f217046%2fcheck-for-pangrams-in-elisp%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown

























          0






          active

          oldest

          votes








          0






          active

          oldest

          votes









          active

          oldest

          votes






          active

          oldest

          votes















          draft saved

          draft discarded
















































          Thanks for contributing an answer to Code Review Stack Exchange!


          • Please be sure to answer the question. Provide details and share your research!

          But avoid


          • Asking for help, clarification, or responding to other answers.

          • Making statements based on opinion; back them up with references or personal experience.

          Use MathJax to format equations. MathJax reference.


          To learn more, see our tips on writing great answers.




          draft saved


          draft discarded














          StackExchange.ready(
          function ()
          StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fcodereview.stackexchange.com%2fquestions%2f217046%2fcheck-for-pangrams-in-elisp%23new-answer', 'question_page');

          );

          Post as a guest















          Required, but never shown





















































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown

































          Required, but never shown














          Required, but never shown












          Required, but never shown







          Required, but never shown







          Popular posts from this blog

          名間水力發電廠 目录 沿革 設施 鄰近設施 註釋 外部連結 导航菜单23°50′10″N 120°42′41″E / 23.83611°N 120.71139°E / 23.83611; 120.7113923°50′10″N 120°42′41″E / 23.83611°N 120.71139°E / 23.83611; 120.71139計畫概要原始内容臺灣第一座BOT 模式開發的水力發電廠-名間水力電廠名間水力發電廠 水利署首件BOT案原始内容《小檔案》名間電廠 首座BOT水力發電廠原始内容名間電廠BOT - 經濟部水利署中區水資源局

          Prove that NP is closed under karp reduction?Space(n) not closed under Karp reductions - what about NTime(n)?Class P is closed under rotation?Prove or disprove that $NL$ is closed under polynomial many-one reductions$mathbfNC_2$ is closed under log-space reductionOn Karp reductionwhen can I know if a class (complexity) is closed under reduction (cook/karp)Check if class $PSPACE$ is closed under polyonomially space reductionIs NPSPACE also closed under polynomial-time reduction and under log-space reduction?Prove PSPACE is closed under complement?Prove PSPACE is closed under union?

          Is my guitar’s action too high? Announcing the arrival of Valued Associate #679: Cesar Manara Planned maintenance scheduled April 23, 2019 at 23:30 UTC (7:30pm US/Eastern)Strings too stiff on a recently purchased acoustic guitar | Cort AD880CEIs the action of my guitar really high?Μy little finger is too weak to play guitarWith guitar, how long should I give my fingers to strengthen / callous?When playing a fret the guitar sounds mutedPlaying (Barre) chords up the guitar neckI think my guitar strings are wound too tight and I can't play barre chordsF barre chord on an SG guitarHow to find to the right strings of a barre chord by feel?High action on higher fret on my steel acoustic guitar