每周挑战:分类和计数

每周挑战:分类和计数

每周挑战307

本周的挑战由Mohammad S. Anwar 提出,旨在通过Python和Perl两种语言的练习,提升大家的编程能力。

挑战及我的解决方案

任务一:顺序检查

任务描述

给定一个整数列表 @ints

请编写一个脚本,将该列表按升序重新排列,并返回与原始列表索引不同的索引值。

我的解决方案

这周的两个任务都比较直接,无需过多解释。我的方法是创建一个新的排序列表 sorted_ints (Perl中为数组)。然后迭代列表索引,比较原始列表和排序列表在相同索引位置的值是否一致。如果不一致,则将该索引添加到差异列表中。

def check_order(ints: list) -> list:    sorted_ints = sorted(ints)    diff_indices = []    for i in range(len(ints)):        if ints[i] != sorted_ints[i]:            diff_indices.append(i)    return diff_indices

示例

$ ./ch-1.py 5 2 4 3 1[0, 2, 3, 4]$ ./ch-1.py 1 2 1 1 3[1, 3]$ ./ch-1.py 3 1 3 2 3[0, 1, 3]

任务二:查找字谜

任务描述

给定一个单词列表 @words

请编写一个脚本,查找任何两个连续的单词,如果它们是字谜,则删除第一个单词并保留第二个单词。重复此过程,直到列表中不再存在字谜,并返回最终列表的元素个数。

我的解决方案

对于此任务,我创建了一个名为 sorted_words 的列表,其中每个单词的字母都按字母顺序排序并忽略大小写。然后,我从列表的倒数第二个元素开始反向迭代。如果当前元素的排序形式与前一个元素相同,则表示找到一对字谜,我将字谜计数器 anagrams 加一。

最终结果为原始列表长度减去字谜对的个数。

def find_anagrams(words: list) -> int:    sorted_words = [''.join(sorted(word.lower())) for word in words]    anagrams_count = 0    for i in range(len(words) - 1, 0, -1):        if sorted_words[i] == sorted_words[i - 1]:            anagrams_count += 1    return len(words) - anagrams_count

示例

$ ./ch-2.py acca dog god perl repl3$ ./ch-2.py abba baba aabb ab ab2

以上就是每周挑战:分类和计数的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/1356065.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年12月13日 19:36:09
下一篇 2025年12月13日 19:36:26

相关推荐

  • pytorch中的随机溶剂(1)

    this text discusses the randomresizedcrop function from the torchvision.transforms.v2 library in python, demonstrating its use with the oxford iiit pe…

    2025年12月13日 好文分享
    000
  • 使用Python,Pydantic和Langchain创建可维护的AI工作流程

    概述与核心概念 本教程演示如何利用Python和Pydantic构建易于维护的AI工作流。我们将重点创建一个可轻松修改和扩展的故事分析系统。 Pydantic模型是现代Python应用中类型安全数据处理的基石。它们允许我们定义数据的结构并自动验证数据,这在AI工作流中至关重要,因为它有助于保持一致性…

    2025年12月13日
    000
  • 为什么WebAssembly(WASM)是高性能Web应用程序的未来

    webassembly (wasm):高性能web应用的未来 Web技术日新月异,从静态HTML页面发展到如今高度互动且复杂的应用。然而,传统的基于JavaScript的Web应用在处理高性能任务时常常力不从心。这时,WebAssembly (Wasm)应运而生,它以接近原生应用的速度在浏览器中运行…

    2025年12月13日
    000
  • 使用Python和简化的库存基本分析

    利用Python和简化方法进行高效的基本面股票分析,在瞬息万变的股票市场中占据优势。本文将深入探讨如何运用Python及自定义模块(例如yfinance3)构建自动化工具,实现股票基本面分析。我们将逐步拆解代码,并阐明每个部分如何有效地收集和处理股票数据。 项目核心功能: 从CSV文件加载和处理多个…

    2025年12月13日
    000
  • 第二天 – 句子,订购,子查询,汇总函数,在数据库中组。

    员工信息表: empid | empname | designation | dept | salary ——-+———+——————-+———–+——– 11 | lakshmi | 软件工程师 | IT | 50000 12 |…

    2025年12月13日
    000
  • 使用Zappa在AWS lambda + API网关上部署数字分类API

    概述 这个项目是一个基于烧瓶的api,可提供给定数字的有趣数学属性。它确定一个数字是素数,完美还是一个阿姆斯特朗的数字,还提供了数字的总和和一个有趣的事实。 > > zappa使在aws lambda api网关上构建和部署无服务器驱动的python应用程序(包括但不限于wsgi web…

    2025年12月13日 好文分享
    000
  • 从零到fastapi英雄:我的hngstage dventure

    从零构建FastAPI应用:我的HNG Stage 0 项目实战 各位后端开发者们,大家好! 本文记录了我完成HNG Stage 0 项目的历程,一个使用FastAPI构建的简单API。这个API实现了三个功能:返回我的注册邮箱、显示当前UTC时间(ISO 8601格式)以及提供项目GitHub仓库…

    2025年12月13日
    000
  • 算法和伪代码简介

    算法概述 算法是什么? 算法是解决问题或完成任务的一系列步骤。 你可以把它想象成一个烹饪食谱: 输入:食材(例如,数据,用户需求)步骤:混合、烘焙(例如,计算、比较)输出:最终菜肴(例如,排序列表,最短路径) 例如,GPS应用使用算法来查找最快路线,它会考虑交通状况、道路封闭情况和距离等因素。 有效…

    2025年12月13日
    000
  • 将布鲁斯基帖子转换为Pixela图的工具

    我创建了一个工具,将我的每日bluesky帖子数量可视化到pixela图表中。源代码已上传至github。 我的帐户图表如下所示: 如您所见,我的Bluesky发帖习惯呈现出明显的间歇性,通常只在有空闲时间时才会发帖。此工具有助于直观地展现这一模式。 工作原理 该工具通过Bluesky API 每日…

    2025年12月13日
    000
  • 如何使用编码代理添加自动单位测试

    利用AI编码代理gitauto自动生成单元测试 单元测试的重要性毋庸置疑,但繁重的开发任务常常使它被搁置。 本文介绍如何利用AI编码代理gitauto,将单元测试的编写自动化,从而提升代码质量,同时不影响主要开发进度。 挑战与初次尝试 以services/github/branch_manager.…

    2025年12月13日
    000
  • 构建我的第一个Python终端游戏:Hangman

    最近,我完成了Codecademy计算机科学101课程中的一个Python项目:一个简单的Hangman(猜字游戏)。虽然是入门级项目,但它让我很好地练习了代码构建、用户输入处理和游戏逻辑管理。游戏规则遵循经典Hangman:程序从预定义词库中随机选择一个单词;玩家逐个猜测字母;猜对则显示字母;猜错…

    2025年12月13日
    000
  • 掌握数据争吵:开发人员的简单指南

    引言 数据争吵是将原始数据转化为可分析的、有价值信息的过程。它包含数据清洗、结构化和增强等步骤,为后续分析奠定坚实基础。 什么是数据争吵? 数据争吵,也称数据清洗或数据准备,是指将原始数据转换为结构化格式的过程。它主要包括以下几个方面: 数据清洗: 清除数据集中的重复项、处理缺失值并纠正错误。数据转…

    2025年12月13日
    000
  • 编号分类API开发HNG任务1

    数字分类API:一个DevOps实践项目 本项目旨在提供一个简单易用的数字数学属性查询接口。该数字分类api接受整数作为输入,返回包含关键属性和趣味事实的结构化json响应。 项目涵盖了软件开发生命周期(sdlc)的各个阶段,从开发和测试到部署和监控,为理解devops实践的集成提供了一个端到端的学…

    2025年12月13日
    000
  • 探索ASGI:Python的Web应用程序异步协议

    LeapCell:Python Web 托管、异步任务和 Redis 的最佳无服务器平台 本文探讨 Python Web 应用中 ASGI 协议与 Uvicorn 服务器的关系。 初学者常疑惑为何 FastAPI 开发需要 Uvicorn,本文将解答此疑问。 Uvicorn 的作用 以下是一个简单的…

    2025年12月13日
    000
  • AWS lambda ric-运行时接口客户端

    为何选择 Lambda RIC? Lambda RIC 提供诸多优势,尤其在处理大型部署方面: Docker 镜像支持更大规模部署 (最大 10GB): 非常适合包含大量资源,例如 OPA 策略、大型代码库 (而非简单的 zip 文件),并能实现更有效的资源管理。 其优化的层管理和缓存机制进一步提升…

    2025年12月13日
    000
  • &#使用seleniumbase

    >我当前正在使用seleniumbase进行python中的web自动化,但是,有时我会收到“未创建的会话”错误:> test16.py – selenium.common.exceptions.sessionnotcreatedexception: message: session n…

    好文分享 2025年12月13日
    000
  • Python Day-抽象,封装

    抽象: – >抽象用于隐藏用户的内部功能。 – >用户仅与该函数的基本实现进行交互,但内部工作已隐藏。 ->用户熟悉“函数的作用”,但他们不知道“它的作用”。->抽象是使用摘要类和摘要方法实现的,abc(抽象基类)模块提供。 > 一个抽象类是无法…

    2025年12月13日
    000
  • GitLab入门:登录指南和初学者提示

    GitLab快速入门:登录及实用技巧 GitLab是一个功能强大的DevOps平台,提供Git仓库管理、CI/CD管道、问题追踪等多种功能,是开发者版本控制和项目协作的理想选择。本文将指导您快速登录GitLab并提供一些初学者实用技巧。 GitLab登录步骤: 访问GitLab网站: 打开官方Git…

    2025年12月13日
    000
  • 我如何在亚马逊上托管我的静态网站

    使用aws s3轻松托管静态网站:一个循序渐进的指南 我最近开始学习云计算并实践AWS,决定使用Amazon S3托管一个简单的静态网站。由于我的网站仅包含HTML和CSS,S3的静态网站托管功能非常适合,无需服务器或后端配置。本文将详细介绍使用AWS管理控制台的设置过程。 为什么选择Amazon …

    2025年12月13日 好文分享
    000
  • pytorch中的随机旋转

    本文档介绍了torchvision.transforms.v2.randomrotation的用法,这是一个用于随机旋转图像的工具。 RandomRotation 参数详解 RandomRotation 的初始化方法接受以下参数: degrees (必需): 指定旋转角度。可以是整数、浮点数,或者一…

    2025年12月13日 好文分享
    000

发表回复

登录后才能评论
关注微信