{"id":"https://openalex.org/W2133039112","doi":"https://doi.org/10.1017/s0956796813000014","title":"Solving the snake cube puzzle in Haskell","display_name":"Solving the snake cube puzzle in Haskell","publication_year":2013,"publication_date":"2013-03-01","ids":{"openalex":"https://openalex.org/W2133039112","doi":"https://doi.org/10.1017/s0956796813000014","mag":"2133039112"},"language":"en","primary_location":{"id":"doi:10.1017/s0956796813000014","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796813000014","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D0C6BD42DB4BAD20F0866F162D723137/S0956796813000014a.pdf/div-class-title-solving-the-snake-cube-puzzle-in-haskell-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"type":"article","indexed_in":["crossref"],"open_access":{"is_oa":true,"oa_status":"bronze","oa_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D0C6BD42DB4BAD20F0866F162D723137/S0956796813000014a.pdf/div-class-title-solving-the-snake-cube-puzzle-in-haskell-div.pdf","any_repository_has_fulltext":false},"authorships":[{"author_position":"first","author":{"id":"https://openalex.org/A5109230348","display_name":"Mark P. Jones","orcid":null},"institutions":[{"id":"https://openalex.org/I126345244","display_name":"Portland State University","ror":"https://ror.org/00yn2fy02","country_code":"US","type":"education","lineage":["https://openalex.org/I126345244"]}],"countries":["US"],"is_corresponding":true,"raw_author_name":"MARK P. JONES","raw_affiliation_strings":["Department of Computer Science, Portland State University, Portland, Oregon, USA (e-mail:","Department of Computer Science, Portland State University, Portland, Oregon, USA ("],"raw_orcid":null,"affiliations":[{"raw_affiliation_string":"Department of Computer Science, Portland State University, Portland, Oregon, USA (e-mail:","institution_ids":["https://openalex.org/I126345244"]},{"raw_affiliation_string":"Department of Computer Science, Portland State University, Portland, Oregon, USA (","institution_ids":["https://openalex.org/I126345244"]}]}],"institutions":[],"countries_distinct_count":1,"institutions_distinct_count":1,"corresponding_author_ids":["https://openalex.org/A5109230348"],"corresponding_institution_ids":["https://openalex.org/I126345244"],"apc_list":null,"apc_paid":null,"fwci":0.0,"has_fulltext":true,"cited_by_count":0,"citation_normalized_percentile":{"value":0.14996199,"is_in_top_1_percent":false,"is_in_top_10_percent":false},"cited_by_percentile_year":null,"biblio":{"volume":"23","issue":"2","first_page":"145","last_page":"160"},"is_retracted":false,"is_paratext":false,"is_xpac":false,"primary_topic":{"id":"https://openalex.org/T12002","display_name":"Computability, Logic, AI Algorithms","score":0.996999979019165,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},"topics":[{"id":"https://openalex.org/T12002","display_name":"Computability, Logic, AI Algorithms","score":0.996999979019165,"subfield":{"id":"https://openalex.org/subfields/1703","display_name":"Computational Theory and Mathematics"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10126","display_name":"Logic, programming, and type systems","score":0.9922999739646912,"subfield":{"id":"https://openalex.org/subfields/1702","display_name":"Artificial Intelligence"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}},{"id":"https://openalex.org/T10715","display_name":"Distributed and Parallel Computing Systems","score":0.9886999726295471,"subfield":{"id":"https://openalex.org/subfields/1705","display_name":"Computer Networks and Communications"},"field":{"id":"https://openalex.org/fields/17","display_name":"Computer Science"},"domain":{"id":"https://openalex.org/domains/3","display_name":"Physical Sciences"}}],"keywords":[{"id":"https://openalex.org/keywords/haskell","display_name":"Haskell","score":0.9801027774810791},{"id":"https://openalex.org/keywords/computer-science","display_name":"Computer science","score":0.8939769864082336},{"id":"https://openalex.org/keywords/functional-programming","display_name":"Functional programming","score":0.8423364162445068},{"id":"https://openalex.org/keywords/cube","display_name":"Cube (algebra)","score":0.6539269685745239},{"id":"https://openalex.org/keywords/programming-language","display_name":"Programming language","score":0.6351044178009033},{"id":"https://openalex.org/keywords/key","display_name":"Key (lock)","score":0.5513114333152771},{"id":"https://openalex.org/keywords/visualization","display_name":"Visualization","score":0.4438023865222931},{"id":"https://openalex.org/keywords/data-structure","display_name":"Data structure","score":0.43301141262054443},{"id":"https://openalex.org/keywords/theoretical-computer-science","display_name":"Theoretical computer science","score":0.3717052936553955},{"id":"https://openalex.org/keywords/artificial-intelligence","display_name":"Artificial intelligence","score":0.2071523666381836},{"id":"https://openalex.org/keywords/mathematics","display_name":"Mathematics","score":0.06050610542297363}],"concepts":[{"id":"https://openalex.org/C2780624054","wikidata":"https://www.wikidata.org/wiki/Q34010","display_name":"Haskell","level":3,"score":0.9801027774810791},{"id":"https://openalex.org/C41008148","wikidata":"https://www.wikidata.org/wiki/Q21198","display_name":"Computer science","level":0,"score":0.8939769864082336},{"id":"https://openalex.org/C42383842","wikidata":"https://www.wikidata.org/wiki/Q193076","display_name":"Functional programming","level":2,"score":0.8423364162445068},{"id":"https://openalex.org/C53051483","wikidata":"https://www.wikidata.org/wiki/Q861555","display_name":"Cube (algebra)","level":2,"score":0.6539269685745239},{"id":"https://openalex.org/C199360897","wikidata":"https://www.wikidata.org/wiki/Q9143","display_name":"Programming language","level":1,"score":0.6351044178009033},{"id":"https://openalex.org/C26517878","wikidata":"https://www.wikidata.org/wiki/Q228039","display_name":"Key (lock)","level":2,"score":0.5513114333152771},{"id":"https://openalex.org/C36464697","wikidata":"https://www.wikidata.org/wiki/Q451553","display_name":"Visualization","level":2,"score":0.4438023865222931},{"id":"https://openalex.org/C162319229","wikidata":"https://www.wikidata.org/wiki/Q175263","display_name":"Data structure","level":2,"score":0.43301141262054443},{"id":"https://openalex.org/C80444323","wikidata":"https://www.wikidata.org/wiki/Q2878974","display_name":"Theoretical computer science","level":1,"score":0.3717052936553955},{"id":"https://openalex.org/C154945302","wikidata":"https://www.wikidata.org/wiki/Q11660","display_name":"Artificial intelligence","level":1,"score":0.2071523666381836},{"id":"https://openalex.org/C33923547","wikidata":"https://www.wikidata.org/wiki/Q395","display_name":"Mathematics","level":0,"score":0.06050610542297363},{"id":"https://openalex.org/C114614502","wikidata":"https://www.wikidata.org/wiki/Q76592","display_name":"Combinatorics","level":1,"score":0.0},{"id":"https://openalex.org/C38652104","wikidata":"https://www.wikidata.org/wiki/Q3510521","display_name":"Computer security","level":1,"score":0.0}],"mesh":[],"locations_count":1,"locations":[{"id":"doi:10.1017/s0956796813000014","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796813000014","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D0C6BD42DB4BAD20F0866F162D723137/S0956796813000014a.pdf/div-class-title-solving-the-snake-cube-puzzle-in-haskell-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"}],"best_oa_location":{"id":"doi:10.1017/s0956796813000014","is_oa":true,"landing_page_url":"https://doi.org/10.1017/s0956796813000014","pdf_url":"https://www.cambridge.org/core/services/aop-cambridge-core/content/view/D0C6BD42DB4BAD20F0866F162D723137/S0956796813000014a.pdf/div-class-title-solving-the-snake-cube-puzzle-in-haskell-div.pdf","source":{"id":"https://openalex.org/S12266929","display_name":"Journal of Functional Programming","issn_l":"0956-7968","issn":["0956-7968","1469-7653"],"is_oa":false,"is_in_doaj":false,"is_core":true,"host_organization":"https://openalex.org/P4310311721","host_organization_name":"Cambridge University Press","host_organization_lineage":["https://openalex.org/P4310311721","https://openalex.org/P4310311702"],"host_organization_lineage_names":["Cambridge University Press","University of Cambridge"],"type":"journal"},"license":null,"license_id":null,"version":"publishedVersion","is_accepted":true,"is_published":true,"raw_source_name":"Journal of Functional Programming","raw_type":"journal-article"},"sustainable_development_goals":[],"awards":[],"funders":[],"has_content":{"pdf":true,"grobid_xml":true},"content_urls":{"pdf":"https://content.openalex.org/works/W2133039112.pdf","grobid_xml":"https://content.openalex.org/works/W2133039112.grobid-xml"},"referenced_works_count":1,"referenced_works":["https://openalex.org/W1556536463"],"related_works":["https://openalex.org/W2112263414","https://openalex.org/W1602185604","https://openalex.org/W3004782279","https://openalex.org/W2028779182","https://openalex.org/W4242678340","https://openalex.org/W2140654465","https://openalex.org/W2129253059","https://openalex.org/W4296274916","https://openalex.org/W1504459189","https://openalex.org/W1755575651"],"abstract_inverted_index":{"Abstract":[0],"We":[1],"describe":[2],"a":[3,16,41],"concise":[4],"and":[5,39,48,72,79],"elegant":[6],"functional":[7,34,60],"program,":[8],"written":[9],"in":[10,84],"Haskell,":[11],"that":[12,81],"computes":[13],"solutions":[14],"for":[15,46,55],"classic":[17],"puzzle":[18],"known":[19],"as":[20],"the":[21,29,33,51,65,74,85],"\u201csnake":[22],"cube.\u201d":[23],"The":[24],"program":[25],"reflects":[26],"some":[27],"of":[28,32,44,67,76],"fundamental":[30],"characteristics":[31],"style,":[35],"identifying":[36],"key":[37],"abstractions,":[38],"defining":[40],"small":[42],"collection":[43],"operators":[45],"manipulating":[47],"working":[49],"with":[50],"associated":[52],"values.":[53],"Well-suited":[54],"an":[56],"introductory":[57],"course":[58],"on":[59],"programming,":[61],"this":[62],"example":[63],"highlights":[64],"use":[66],"visualization":[68],"tools":[69],"to":[70],"explain":[71],"demonstrate":[73],"choices":[75],"data":[77],"structures":[78],"algorithms":[80],"are":[82],"used":[83],"development.":[86]},"counts_by_year":[],"updated_date":"2026-05-27T06:14:07.914337","created_date":"2025-10-10T00:00:00"}
