自动化面试常见算法题!

1、实现一个数字的反转,比如输入12345,输出54321

num = 12345
num_str = str(num)
reversed_num_str = num_str[::-1]
reversed_num = int(reversed_num_str)
print(reversed_num)  # 输出 54321
  • 代码解析:首先将输入的数字转换为字符串,然后使用切片操作将字符串反转,最后再将反转后的字符串转换回数字类型。

2、统计在一个队列中的数字,有多少个正数,多少个负数,如[1,3,5,7,0,-1,-9,-4,-5,8]

nums = [1, 3, 5, 7, 0, -1, -9, -4, -5, 8]
positive_count = 0
negative_count = 0

for num in nums:
    if num > 0:
        positive_count += 1
    elif num < 0:
        negative_count += 1

print(f"正数数量:{positive_count},负数数量:{negative_count}")
  • 代码解析:首先定义了一个数字列表 nums,然后用变量 positive_count和negative_count 分别记录其中的正数和负数数量。循环遍历这个列表,对于每个数字,如果它是正数则正数数量加一,否则如果是负数则负数数量加一。最后输出正数和负数数量的统计结果。

3、一个数的阶乘运算,求结果,如求5的阶乘结果。

n = 5  # 求 5 的阶乘
factorial = 1  # 阶乘的初始值为 1

for i in range(1, n+1):
    factorial *= i  # 依次乘以 1, 2, 3, ..., n

print(factorial)  # 输出 120
  • 代码解析:首先定义了待求阶乘的数 n,然后将阶乘的初始值设为 1。在循环中,使用 range(1, n+1) 来遍历 1 到 n 这n个数的值。对于每个数,用 factorial 依次乘以它,最终得到的结果即为阶乘。最后输出结果

4、1加到N的阶层之和,比如N=4, result = (1! + 2! + 3! + 4!)

n = 4
factorial_sum = 0  # 1到N的阶层之和
result = 0  # 最终的结果

# 循环计算1到N的阶层之和
for i in range(1, n+1):
    factorial = 1  # 用来记录i的阶层
    for j in range(1, i+1):
        factorial *= j
    factorial_sum += factorial

# 累加到结果中
result += factorial_sum

print(result)  # 输出 33
  • 代码解析:首先定义了待求解的数 n 和计算 1 到 N 的阶层之和的变量 factorial_sum。在循环中,使用两层嵌套循环来计算 i 的阶层,然后把所有阶层求和得到 factorial_sum。最后将 factorial_sum 加入到最终结果 result 中。最后输出结果。

5、求出1000以内的完全数

for n in range(2, 1001):
    factors = []  # 用来存储n的因子
    for i in range(1, n):
        if n % i == 0:
            factors.append(i)  # 将i加入到n的因子列表中

    if sum(factors) == n:
        print(n)
  • 代码解析:外层循环 for n in range(2, 1001) 遍历所有可能的完全数,即从2到1000。在内层循环 for i in range(1, n) 中,使用 n % i == 0 来判断i是否是n的因子,如果是则将它加入到因子列表 factors 中。在循环结束后,使用 sum(factors) == n 来判断所有因子的和是否等于n,如果是则说明n是完全数,输出它的值即可。
  • 完全数是指除自身外所有因子之和等于自身的数。其中最经典的两个完全数是6和28,它们的因子分别是1, 2, 3和1, 2, 4, 7, 14。

6、求出1000以内的水仙花数

for n in range(100, 1000):
    # 将 n 的每一位取出来,计算它们的立方和
    digits = [int(d) for d in str(n)]
    digit_cubes_sum = sum(d ** 3 for d in digits)

    # 如果立方和等于 n,则说明这是一个水仙花数
    if digit_cubes_sum == n:
        print(n)
  • 代码解析:外层循环 for n in range(100, 1000) 遍历所有三位数,内层使用了列表推导式和 sum() 函数来计算 n 的每个数字的立方和。在判断时,如果立方和等于 n,说明 n 是一个水仙花数,将它输出即可。
  • 水仙花数是指一个 n 位数(n≥3)它的每个位上的数字的 n 次幂之和等于它本身。比如 153 就是一个水仙花数,因为 1^3 + 5^3+ 3^3 = 153.

7、求出1000以内的回文数

for n in range(100, 1000):
    # 将 n 转换为字符串,并将字符串反转后再转成数字
    reversed_n = int(str(n)[::-1])

    # 如果翻转后的数等于 n,则说明 n 是一个回文数
    if reversed_n == n:
        print(n)
  • 代码解析:外层循环 for n in range(100, 1000) 遍历所有三位数,将每个数字转换成字符串,然后使用字符串切片 [::-1] 反转它,并将反转后的字符串转回数字。在判断时,如果反转后的数等于 n,则说明 n 是一个回文数,将它输出即可。
  • 回文数是指一个数字从左往右和从右往左读都是一样的,比如 121、1221。

8、实现一个数字的斐波那契数列

# 方式一:循环实现
def fib(n):
    a, b = 0, 1
    for i in range(n):
        a, b = b, a + b
    return a
# 测试代码
n = 10
print([fib(i) for i in range(n)])  # 输出结果为 [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]

# 方式二:递归实现
def fib(n):
    if n <= 1:
        return n
    else:
        return fib(n-1) + fib(n-2)
# 测试代码
n = 10
print([fib(i) for i in range(n)])  # 输出结果为 [0, 1, 1, 2, 3, 5, 8, 13, 21, 34]
  • 代码解析:
    • **方式一(循环实现):初始化 a 和 b 为 0 和 1,然后使用 **for 循环遍历 0 到 n-1,每次将 a 和 b 的值更新为 b 和 a+b,最后返回 a。
    • **方式二(递归实现):首先判断 n 的值是否小于等于 1,如果是,则直接返回 n。否则,递归调用 **fib(n-1) 和 fib(n-2) 并返回它们的和。
  • 斐波那契数列是指从 0 和 1 开始,后续每个数都等于前两个数之和的数列。其数值为:1、1、2、3、5、8、13、21、34……在数学上,这一数列以如下递推的方法定义:F(0)=1,F(1)=1, F(n)=F(n - 1)+F(n - 2)(n ≥ 2,n ∈ N*)

9、统计列表1~9999中包含3的元素的总个数

import re

# 方式一:循环实现
count = 0

# 遍历 1~9999 中的每个数字,将数字转换成字符串并查找其中是否包含字符 3
for i in range(1, 10000):
    if '3' in str(i):
        count += 1

print(count)  # 输出结果为 3439

# 方式二:循环+正则匹配实现
theList = list(filter(lambda x: re.match('(.*?)3(.*?)',str(x)) ,a))
print(f"列表[1~9999]中包含3的元素总个数为:{len(theList)}") # 输出结果为 3439

代码解析:

  • 方式一(循环):使用 for 循环遍历 1~9999 中的每个数字,并将每个数字转换成字符串,然后查找其中是否包含字符 3。如果包含,则将计数器加 1。最后,计数器的值就是包含数字 3 的元素的个数
  • 方式二(循环+正则匹配): re.match() 函数用于检查列表 a 中的每个元素是否包含数字3。正则表达式 (.*?)3(.*?) 匹配任何包含数字3的字符串,无论它在字符串中的位置如何。 filter() 函数用于创建一个新列表,其中仅包含与正则表达式匹配的 a 中的元素。 lambda 函数用于定义一个简单的函数,它接受一个参数 x ,并且如果 re.match('(.*?)3(.*?)',str(x)) 返回一个匹配对象(即如果 x 包含数字3),则返回 True ,否则返回 False 。 结果列表被赋值给变量 theList 。 - len() 函数用于计算 theList 的长度,这给出了在范围[1, 9999]中包含数字3的元素的总数。

10、写一个冒泡排序的算法程序

def bubble_sort(arr):
    n = len(arr)
    # 遍历 n 次
    for i in range(n):
        # 第 i 次遍历,找出未排序部分的最大元素并将其放到末尾
        for j in range(n - i - 1):
            if arr[j] > arr[j + 1]:
                arr[j], arr[j + 1] = arr[j + 1], arr[j]
            
# 测试代码            
arr = [5, 2, 8, 4, 1]
bubble_sort(arr)
print(arr)  # 输出结果为 [1, 2, 4, 5, 8]
  • 代码解析: bubble_sort() 函数接收一个列表 arr,并将其进行冒泡排序。具体实现时,使用两个嵌套的循环对列表中的所有元素进行比较,如果相邻两个元素的顺序相反,则交换它们的顺序,直到整个列表都排好序。 **先定义了一个列表 **arr,然后调用 bubble_sort(arr) 对其进行冒泡排序,并输出排序后的结果。
  • 冒泡排序是一种基本的排序算法,也是最简单的一种排序算法之一。它的基本思想是:通过重复交换相邻的两个元素来实现排序。具体来说,冒泡排序的过程如下: 从列表的第一个元素开始,依次比较相邻的两个元素,如果第一个元素大于第二个元素,则交换它们的位置; 继续比较第二个元素和第三个元素,如果第二个元素大于第三个元素,则交换它们的位置; 重复上述步骤,直到比较到列表的最后一个元素; 重复上述步骤,直到列表中的所有元素都按照从小到大的顺序排列为止。

11、用python实现二分法排序

def binary_search(arr, target):
    low, high = 0, len(arr) - 1

    while low <= high:
        mid = (low + high) // 2
        if arr[mid] == target:
            return mid
        elif arr[mid] < target:
            low = mid + 1
        else:
            high = mid - 1

    return -1

# 测试代码
arr = [1, 3, 4, 6, 8, 9, 11, 12, 13, 16]
target = 9
pos = binary_search(arr, target)
if pos == -1:
    print("元素不在列表中")
else:
    print("元素在列表中的下标为:", pos)
  • 代码解析: binary_search() 函数接收一个有序列表 arr 和一个待查找的元素 target,并返回该元素在列表中的下标(从 0 开始计数);如果该元素不在列表中,则返回 -1。二分查找算法通过不断地将待查找部分缩小一半来实现查找 **有序列表 **arr 和一个待查找的元素 target,然后调用 binary_search(arr, target) 函数查找该元素在列表中的下标,并输出结果。
  • 二分查找,也叫二分查找、折半查找,是一种在有序数组中查找某一特定元素的搜索算法。二分查找每次将查找区间减半,直到找到目标元素,或者确定目标元素不存在于数组中。具体来说,二分查找的基本步骤如下: 首先,令左侧下标 low 等于数组的第一个元素下标,右侧下标 high 等于数组的最后一个元素下标,计算中间下标 mid; 比较中间下标的值与目标值的大小关系。若相等,则返回中间下标;若小于目标值,则目标值在中间下标的右侧,将 low 置为 mid + 1;否则目标值在中间下标的左侧,将 high 置为 mid - 1; 重复上述步骤,直到 low 大于 high,表示查找区间为空,返回 -1。

12、写一个快排的算法程序

def quick_sort(arr):
    if len(arr) <= 1:
        return arr
    pivot = arr[len(arr) // 2]  # 选择中间的元素作为基准值
    left = [x for x in arr if x < pivot]  # 小于基准值的放在左边
    mid = [x for x in arr if x == pivot]  # 等于基准值的放在中间
    right = [x for x in arr if x > pivot]  # 大于基准值的放在右边
    return quick_sort(left) + mid + quick_sort(right)

# 测试代码
arr = [5, 2, 8, 4, 1]
arr_sorted = quick_sort(arr)
print(arr_sorted)  # 输出结果为 [1, 2, 4, 5, 8]
  • 代码解析: quick_sort() 函数接收一个列表 arr,并返回排序后的新列表。具体实现时,先选择列表中间的元素作为基准值 pivot,然后将列表分成三部分:小于基准值的放在左边,等于基准值的放在中间,大于基准值的放在右边。然后递归地对左、右两个子列表进行排序。 **先定义了一个列表 **arr,然后调用 quick_sort(arr) 将其进行快速排序,并输出排序后的结果。
  • 快速排序(Quick Sort)是一种常用的排序算法,属于交换排序的一种。其基本思想是:选定一个基准值,将列表分成两个子列表,小于基准值的放在左边,大于或等于基准值的放在右边,然后递归地对左、右两个子列表进行排序,最终将整个列表排序。具体来说,快速排序算法的基本步骤如下: 确定基准值:选取一个基准值,在列表中选择一个元素作为基准值。 分割:将列表按照基准值进行分割,小于基准值的放在左边,大于或等于基准值的放在右边。分割后,将列表分成了两个部分,左边部分的所有元素都小于基准值,右边部分的所有元素都大于或等于基准值。 递归:对左、右两个子列表分别进行快速排序的递归操作,直到排序完成。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:/a/494779.html

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

ARMday7作业

实现三个按键的中断&#xff0c;现象和代码 do_ipr.c #include "stm32mp1xx_gic.h" #include "stm32mp1xx_exti.h" extern void printf(const char *fmt, ...); unsigned int i 0; void do_irq(void) {//获取要处理的中断的中断号unsigned int irqnoGI…

离线数仓(八)【DWD 层开发】

前言 1、DWD 层开发 DWD层设计要点&#xff1a; &#xff08;1&#xff09;DWD层的设计依据是维度建模理论&#xff08;主体是事务型事实表&#xff08;选择业务过程 -> 声明粒度 -> 确定维度 -> 确定事实&#xff09;&#xff0c;另外两种周期型快照事实表和累积型…

信号处理--情绪分类数据集DEAP预处理(python版)

关于 DEAP数据集是一个常用的情绪分类公共数据&#xff0c;在日常研究中经常被使用到。如何合理地预处理DEAP数据集&#xff0c;对于后端任务的成功与否&#xff0c;非常重要。本文主要介绍DEAP数据集的预处理流程。 工具 图片来源&#xff1a;DEAP: A Dataset for Emotion A…

如何备考2025年AMC8竞赛?吃透2000-2024年600道真题(免费送题

最近有家长朋友问我&#xff0c;现在有哪些类似于奥数的比赛可以参加&#xff1f;我的建议可以关注下AMC8的竞赛&#xff0c;类似于国内的奥数&#xff0c;但是其难度要比国内的奥数低一些&#xff0c;而且比赛门槛更低&#xff0c;考试也更方便。比赛的题目尤其是应用题比较有…

肿瘤靶向肽 iRGD peptide环肽 1392278-76-0 c(CRGDKGPDC)

RGD环肽 c(CRGDKGPDC)&#xff0c;iRGD peptide 1392278-76-0 结 构 式&#xff1a; H2N-CRGDKGPDC-OH(Disulfide Bridge:C1-C9) H2N-Cys-Arg-Gly-Asp-Lys-Gly-Pro-Asp-Cys-COOH(Disulfide Bridge:Cys1-Cys9) 氨基酸个数&#xff1a; 9 C35H57N13O14S2 平均分子量:…

聊聊低代码产品的应用场景

随着数字化转型的不断深入&#xff0c;企业对于快速开发和迭代软件应用的需求也越来越迫切。而在这样的背景下&#xff0c;低代码产品应运而生&#xff0c;成为了一种热门的技术解决方案。本文将解读低代码产品的定义并探讨其应用场景。 一、低代码产品的定义 低代码产品是一种…

企业计算机服务器中了rmallox勒索病毒怎么办,rmallox勒索病毒解密流程步骤

在网络技术飞速发展的时代&#xff0c;越来越多的企业离不开网络办公&#xff0c;通过网络开展各项工作业务成为企业的常态&#xff0c;这也被国外众多黑客组织盯上的原因&#xff0c;近期&#xff0c;网络勒索病毒攻击的事件频发&#xff0c;越来越多的企业开始重视企业数据安…

Rust语言中Regex正则表达式,匹配和查找替换等

官方仓库&#xff1a;https://crates.io/crates/regex 文档地址&#xff1a;regex - Rust github仓库地址&#xff1a;GitHub - rust-lang/regex: An implementation of regular expressions for Rust. This implementation uses finite automata and guarantees linear tim…

leetcode:2138. 将字符串拆分为若干长度为 k 的组(python3解法)

难度&#xff1a;简单 字符串 s 可以按下述步骤划分为若干长度为 k 的组&#xff1a; 第一组由字符串中的前 k 个字符组成&#xff0c;第二组由接下来的 k 个字符串组成&#xff0c;依此类推。每个字符都能够成为 某一个 组的一部分。对于最后一组&#xff0c;如果字符串剩下的…

【SAP2000】在框架结构中应用分布式面板荷载Applying Distributed Panel Loads to Frame Structures

在框架结构中应用分布式面板荷载 Applying Distributed Panel Loads to Frame Structures 使用"Uniform to Frame"选项,可以简单地将荷载用于更多样化的情况。 With the “Uniform to Frame” option, loads can be easily used for a greater diversity of situat…

如何高效阅读嵌入式代码

大家好&#xff0c;今天给大家介绍如何高效阅读嵌入式代码&#xff0c;文章末尾附有分享大家一个资料包&#xff0c;差不多150多G。里面学习内容、面经、项目都比较新也比较全&#xff01;可进群免费领取。 高效阅读嵌入式代码需要一些技巧和实践经验。以下是一些建议&#xff…

Sublime 彻底解决中文乱码

1. 按ctrl&#xff0c;打开Console&#xff0c;输入如下代码&#xff1a; import urllib.request,os; pf Package Control.sublime-package; ipp sublime.installed_packages_path(); urllib.request.install_opener( urllib.request.build_opener( urllib.request.ProxyHand…

excel统计分析——单向分组资料的协方差分析

参考资料&#xff1a;生物统计学 单向分组资料是具有一个协变量的单因素方差分析资料。 操作案例如下&#xff1a; 1、对x和y进行方差分析 由方差分析表可知&#xff1a;4种处理间&#xff0c;x存在显著差异&#xff0c;而y在处理间差异不显著。需要进行协方差分析&#xff0c…

【C语言】linux内核pci_iomap

一、pci_iomap /** pci_iomap 是一个用于映射 PCI 设备的 BAR&#xff08;Base Address Register&#xff0c;基地址寄存器&#xff09;的函数。* 此函数返回指向内存映射 IO 的指针&#xff0c;用于直接访问 PCI 设备的内存或 I/O 空间。* * 参数:* dev - 指向pci_dev结构的指…

IP如何异地共享文件?

【天联】 组网由于操作简单、跨平台应用、无网络要求、独创的安全加速方案等原因&#xff0c;被几十万用户广泛应用&#xff0c;解决了各行业客户的远程连接需求。采用穿透技术&#xff0c;简单易用&#xff0c;不需要在硬件设备中端口映射即可实现远程访问。 异地共享文件 在…

使用GO对PostgreSQL进行有意思的多线程压测

前言 针对PostgreSQL进行压缩&#xff0c;有很多相关的工具。有同学又要问了&#xff0c;为何还要再搞一个&#xff1f;比如&#xff0c;pgbench, sysbench之类的&#xff0c;已经很强大了。是的&#xff0c;它们都很强大。但有时候&#xff0c;在一些特殊的场景&#xff0c;可…

功能强大的国外商业PHP在线教育系统LMS源码/直播课程系统

功能强大的国外商业PHP在线教育系统LMS/在线教育市场源码/直播课程系统 Proacademy是在线教育一体化的解决方案&#xff0c;用于创建类似于Udemy、Skillshare、Coursera这种在线教育市场。 这个平台提供在线课程&#xff0c;现场课程&#xff0c;测验等等&#xff0c;并有一个…

单链表交叉分离,运用头插法,尾插法(算法库应用)

原文博客链接:单链表分离(头插法和尾插法的结合,理解指针变换)_3.对任务1或者2中创建的某一个单链表{a1,b1,a2,b2,...,an,bn},编写一个算法将-CSDN博客 函数实现: /************************************************** 函数名:separate_LinkList 功 能: 把一个链表,交叉新建…

如何在jupyter使用新建的虚拟环境以及改变jupyter启动文件路径。

对于刚刚使用jupyter的新手来说&#xff0c;经常不知道如何在其中使用新建的虚拟环境内核&#xff0c;同时&#xff0c;对于默认安装的jupyter&#xff0c;使用jupyter notebook命令启动 jupyter 以后往往默认是C盘的启动路径&#xff0c;如下图所示&#xff0c;这篇教程将告诉…

HBase的Python API操作(happybase)

一、Windows下安装Python库&#xff1a;happyhbase pip install happybase -i https://pypi.tuna.tsinghua.edu.cn/simple 二、 开启HBase的Thrift服务 想要使用Python API连接HBase&#xff0c;需要开启HBase的Thrift服务。所以&#xff0c;在Linux服务器上&#xff0c;执行…