首页 > 编程语言 >python-春游

python-春游

时间:2024-08-31 12:21:23浏览次数:6  
标签:同学 元素 python 编号 range 春游 报出 input

[题目描述]
老师带领同学们春游。已知班上有 N 位同学,每位同学有从 0 到 N−1 的唯一编号。到了集合时间,老师确认是否所有同学都到达了集合地点,就让同学们报出自己的编号。到达的同学都会报出自己的编号,不会报出别人的编号,但有的同学很顽皮,会多次报出。你能帮老师找出有哪些同学没有到达吗 ?
输入:
输入包含 2 行。第一行包含两个整数 N 和 M,表示班级有 N 位同学,同学们共有 M 次报出编号。约定 2≤N,M≤1000。
第二行包含 M 个整数,分别为 M 次报出的编号。约定所有编号是小于 N 的非负整数。
输出:
输出一行。如果所有同学都到达,则输出 N;否则由小到大输出所有未到达的同学编号,空格分隔。
样例输入1
3 3
0 2 1

样例输出1
3

样例输入2
3 5
0 0 0 0 0

样例输出2
1 2

来源/分类(难度系数:一星
数列 矩阵


完整代码展示:
a,b=map(int,input().split())
c=list(map(int,input().split()))
d=[]
for i in range(0,len(c)):
      if c[i] not in d:
           d.append(c[i])
d.sort()
e=[]
for j in range(0,a):
      e.append(j)
if d==e:
     print(a)                                                            else:
       for k in range(0,len(e)):
             if e[k] not in d:
                  print(e[k],'',end="")


代码解释:
a,b=map(int,input().split()) ”,让用户输入总人数a和报号的次数b。
c=list(map(int,input().split())) ”,让用户输入每次报的编号,并将其储存在列表c中。
d=[]
 for i in range(0,len(c)):
       if c[i] not in d:
            d.append(c[i])  
”,建立一个空列表d,接着依次遍历c中的元素,判断该元素是否在列表d中,如果不在:则将该元素添加进d中。
d.sort()
 e=[]
 for j in range(0,a):
 e.append(j)
          ”,对d中元素进行升序排序,接着建立一个空列表e,依次将0~a-1的a个元素添加进e中。
if d==e:
       print(a)
else:
       for k in range(0,len(e)):
              if e[k] not in d:
                   print(e[k],'',end="")
”,判断d是否等于e,如果是:打印a,否则遍历e中元素,判断e[k]是否在d中,如果不在:打印e[k],每两个符合条件的元素之间插入一个空格。


运行效果展示:

9f60d17a8bf94ed98bd3b5d52bf513c5.jpg

e35f899444f84815ae92e66357be63d4.jpg 

          (声明:以上内容均为原创)

 

标签:同学,元素,python,编号,range,春游,报出,input
From: https://blog.csdn.net/2401_83954530/article/details/141750803

相关文章

  • 基于Python的机器学习系列(17):梯度提升回归(Gradient Boosting Regression)
    简介        梯度提升(GradientBoosting)是一种强大的集成学习方法,类似于AdaBoost,但与其不同的是,梯度提升通过在每一步添加新的预测器来减少前一步预测器的残差。这种方法通过逐步改进模型,能够有效提高预测准确性。梯度提升回归的工作原理        在梯度提升......
  • 基于Python的机器学习系列(16):扩展 - AdaBoost
    简介        在本篇中,我们将扩展之前的AdaBoost算法实现,深入探索其细节并进行一些修改。我们将重点修复代码中的潜在问题,并对AdaBoost的实现进行一些调整,以提高其准确性和可用性。1.修复Alpha计算中的问题        在AdaBoost中,如果分类器的错误率e为0,则......
  • Python库的位置
    1,操作系统命令行看系统python的库wherepythonC:\Users\augus\AppData\Local\Microsoft\WindowsApps\python.exe>>>foriteminsys.path:...print(item)...C:\ProgramFiles\WindowsApps\PythonSoftwareFoundation.Python.3.12_3.12.1520.0_x64__qbz5n2kfra......
  • (2024最新毕设合集)基于SpringBoot的校园设备维修管理系统-16364|可做计算机毕业设计JAV
    基于Springboot的校园设备维修管理系统的设计与实现摘 要基于Springboot的校园设备维修管理系统的设计与实现是一个结合了网络技术和信息管理的项目。该系统能满足校园报修管理的实际需求,通过网络进行信息管理,使得设备维修更加及时有效。本设计主要实现集人性化、高效率、......
  • [Python手撕]大数加法
    num1=input()num2=input()defcompare(num1,num2):foriinrange(len(num1)):ifnum1[i]>num2[i]:return0elifnum1[i]<num2[i]:return1return2#解析符号flag1=0flag2=0ifnum1[0]=="-......
  • [Python手撕]环的检测
    检测环快慢指针法是一种用于检测链表中是否存在环的有效方法,同时也可以找到环的起点。该方法的原理基于两个指针在链表上同时移动,其中一个移动得更快,而另一个移动得更慢。检测环的存在:使用两个指针,一个称为快指针(fast),一个称为慢指针(slow)。在每一步中,快指针向前移动两步,而慢......
  • [Python手撕]二分法
    二分法二分法的几个位置比如01234567891233333456有时候想要寻找小于3的最大数字有时候想要寻找第一个满足>=3的数字,有时候想要寻找最后一个满足>=3的数字,有时候想要寻找小于4的最大数字nums=[1,2,3,4,5,5,5,5,5,6,7,8,9]n=......
  • [Python手撕]TOPK
    TOPK问题描述:从arr[1,n]这n个数中,找出最大的k个数,这就是经典的TopK问题。栗子:从arr[1,12]={5,3,7,1,8,2,9,4,7,2,6,6}这n=12个数中,找出最大的k=5个。整体排序排序是最容易想到的方法,将n个数排序之后,取出最大的k个,即为所得。伪代码:sort(arr,1,n);returnarr[1,k];......
  • 豆包 API 调用示例代码详解-Python版
    文章目录豆包API调用示例代码详解-Python版一、事前准备二、所需Python包三、代码详解五、源码下载四、总结豆包官方API文档豆包API调用示例代码详解-Python版在本文中,我们将详细介绍如何使用Python调用豆包API,并提供相关的事前准备和代码执行步骤。一、......
  • 使用 Python 实现自动化办公
    使用Python实现自动化办公在现代办公环境中,自动化是提高工作效率和减少人为错误的重要手段之一。Python是一种功能强大且灵活的编程语言,可以轻松地实现自动化办公任务。下面是一个简单的示例,展示如何使用Python实现自动化办公:需求:假设我们有一个Excel文件,名为"报表.xls......