19. 现有学生成绩与对应等级:0~60:D、61~80 C、81~90 B、91~100 A,编写脚本实现当输入范围区间内的数字时打印出对应的等级,输入其他字符时提示“请输入数字”并退出脚本?

时间: 2024-03-08 10:50:19 浏览: 118
以下是 Python3 的实现代码: ```python score = input("请输入学生成绩:") if not score.isdigit(): print("请输入数字!") else: score = int(score) if score < 0 or score > 100: print("无效的成绩范围!") elif score < 61: print("D") elif score < 81: print("C") elif score < 91: print("B") else: print("A") ``` 代码解释: 1. 首先获取用户输入的成绩,判断是否为数字,如果不是数字,直接输出提示信息并退出脚本; 2. 如果是数字,将字符串类型的成绩转换为整型; 3. 判断成绩范围是否合法,如果不在 0~100 的范围内,输出无效范围的提示信息; 4. 根据成绩范围输出相应的等级。
相关问题

r语言:1. 有如下56名同学的成绩:59 90 74 32 46 93 41 89 96 93 42 96 88 35 66 77 63 63 31 41 51 60 76 75 50 41 90 45 47 69 99 92 37 97 91 70 76 81 98 59 95 79 90 33 87 31 37 68 76 38 40 37 86 61 34 59,其对应的学生姓名分别是Stud1—Stud56,请将90-100标注为A,80-89标注为B,70-79标注为C,60-69标注为D,50-59标注为E,40-49标注为F,30-39标注为G。然后输出每个相同标签下同学的姓名!如下例: A:Stud2 …… B:Stud8 …… C: 提示:可以将数据放入txt文本文档,然后使用read.table 函数读取,使用which函数处理成绩

这是一个R语言的问题,我将会使用R语言来回答。 首先,我们可以将成绩数据放到一个文本文件中,如“grades.txt”,每行一个成绩,然后使用以下代码读取数据: ``` grades <- read.table("grades.txt") ``` 接下来,我们可以使用which函数将成绩转换为相应的等级: ``` levels <- c("G", "F", "E", "D", "C", "B", "A") grade_labels <- levels[cut(grades$V1, breaks=c(0, 30, 40, 50, 60, 70, 80, 90, 100), labels=levels)] ``` 这里,我们使用了cut函数将成绩划分为不同的区间,并使用labels参数将区间标签设置为相应的等级。 接下来,我们可以将学生姓名与对应的等级数据合并: ``` students <- paste("Stud", 1:length(grades$V1), sep="") grades_df <- data.frame(students, grade_labels) ``` 最后,我们可以使用split函数按照等级将学生姓名分组: ``` groups <- split(grades_df$students, grades_df$grade_labels) ``` 这将会生成一个名为“groups”的列表,其中每个元素表示一个等级,其对应的学生姓名存储在一个字符向量中。 我们可以使用以下代码输出每个等级下的学生姓名: ``` for (i in seq_along(groups)) { cat(levels[i], ": ", paste(groups[[i]], collapse=", "), "\n") } ``` 这将会输出类似以下的结果: ``` G : Stud4, Stud15, Stud20, Stud37, Stud43 F : Stud7, Stud11, Stud25, Stud28, Stud46, Stud47, Stud49, Stud54 E : Stud5, Stud21, Stud22, Stud24, Stud38, Stud40, Stud51 D : Stud16, Stud17, Stud26, Stud27, Stud42, Stud44, Stud48, Stud56 C : Stud1, Stud13, Stud31, Stud35, Stud50 B : Stud8, Stud14, Stud23, Stud34, Stud39, Stud45, Stud52 A : Stud2, Stud9, Stud10, Stud12, Stud18, Stud19, Stud29, Stud30, Stud32, Stud33, Stud36, Stud41, Stud53, Stud55 ```

(train_images, train_labels), (test_images, test_labels) = keras.datasets.cifar100.load_data(label_mode='fine') # 定义分类字典 class_dict = { 0: [0, 53, 57, 83], 1: [1, 3, 4, 6, 7, 14, 15, 18, 19, 21, 24, 26, 27, 29, 30, 31, 32, 34, 36, 38, 42, 43, 44, 45, 50, 55, 63, 64, 65, 66, 67, 72, 73, 74, 75, 77, 78, 79, 80, 88, 91, 93, 95, 97, 99], 2: [2, 11, 35, 46, 98], 3: [5, 9, 10, 16, 20, 22, 25, 28, 39, 40, 41, 61, 84, 86, 87, 94], 4: [12, 17, 37, 68, 76], 5: [23, 33, 49, 60, 71], 6: [47, 51, 52, 54, 56, 59, 62, 70, 82, 92, 96], 7: [8, 13, 48, 58, 69, 81, 85, 89, 90] } train_labels = np.zeros((train_labels.shape[0], 8)) test_labels = np.zeros((test_labels.shape[0], 8)) for i in range(8): train_labels[:, i] = np.any([train_labels[:, class_dict[i][j]] == 1 for j in range(len(class_dict[i]))], axis=0) test_labels[:, i] = np.any([test_labels[:, class_dict[i][j]] == 1 for j in range(len(class_dict[i]))], axis=0)

这段代码的作用是将 CIFAR-100 数据集中的 100 个类别划分为 8 个超类,并将每个样本的标签转换为一个 8 维的 one-hot 向量,其中每个维度代表一个超类。具体来说,根据 `class_dict` 中的超类定义,对每个超类中包含的类别在原始标签中进行逻辑或运算,得到一个布尔数组,然后将这个数组中任意一个为 True 的位置对应的 one-hot 向量的对应维度设为 1。 这段代码本身没有明显的错误,但需要注意的是,如果你要使用这段代码,需要先导入 `numpy` 和 `keras` 库。而且,这个划分方式可能并不适合所有的任务,需要根据具体情况进行调整。
阅读全文

相关推荐

对以下matlab代码进行算法分析和算法步骤描述 clc clear all zb=[413 359 403 343 383.5 351 381 377.5 339 376 335 383 317 362 334.5 353.5 333 342 282 325 247 301 219 316 225 270 280 292 290 335 337 328 415 335 432 371 418 374 444 394 251 277 234 271 225 265 212 290 227 300 256 301 250.5 306 243 328 246 337 314 367 315 351 326 355 327 350 328 342.5 336 339 336 334 331 335 371 330 371 333 388.5 330.5 411 327.5 419 344 411 343 394 346 342 342 342 348 325 372 315 374 342 372 345 382 348.5 380.5 351 377 348 369 370 363 371 353 354 374 363 382.5 357 387 351 382 369 388 335 395 381 381 391 375 392 366 395 361 398 362 401 359 405 360 410 355 408 350 415 351 418 347 422 354 418.5 356 405.5 364.5 405 368 409 370 417 364 420 370 424 372 438 368 438.5 373 434 376 438 385 440 392 447 392 448 381 444.5 383 441 385 440.5 381.5 445 380 444 360 ]; xla=[1 75 1 78 2 44 3 45 3 65 4 39 4 63 5 49 5 50 6 59 7 32 7 47 8 9 8 47 9 35 10 34 11 22 11 26 12 25 12 471 14 21 15 7 15 31 16 14 16 38 17 40 17 42 17 81 18 81 18 83 19 79 20 86 21 22 22 372 22 13 23 13 23 383 24 13 24 25 25 11 26 27 26 10 27 12 28 29 28 15 29 30 30 7 30 48 31 32 31 34 32 33 33 34 33 8 34 9 35 45 36 35 36 37 36 16 36 39 37 7 38 39 38 41 39 40 40 2 41 17 41 92 42 43 43 2 43 72 44 3 45 46 46 8 46 55 47 48 47 6 47 5 48 61 49 50 49 53 50 51 51 52 51 59 52 56 53 52 53 54 54 55 54 63 55 3 56 57 57 58 57 60 57 4 58 59 60 62 61 60 62 4 62 85 63 64 64 65 64 76 65 66 66 67 66 76 67 44 67 68 68 69 68 75 69 70 69 71 69 1 70 2 70 43 71 72 71 74 72 73 73 74 73 18 74 1 74 80 75 76 76 77 77 78 77 19 78 79 79 80 80 18 81 82 82 83 82 90 83 84 84 85 85 20 86 87 86 88 87 88 87 92 88 89 88 91 89 20 89 84 89 90 90 91 91 92 ]; for i=143:-1:1 if xla(i,2)>92 xla(i,:)=[]; end end a=ones(92,92)*inf; for i=1:92 a(i,i)=0; end for k=1:140 i=xla(k,1);j=xla(k,2); sss=sqrt((zb(i,1)-zb(j,1))^2+(zb(i,2)-zb(j,2))^2); a(i,j)=sss; a(j,i)=sss; end

clc clear all zb=[413 359 403 343 383.5 351 381 377.5 339 376 335 383 317 362 334.5 353.5 333 342 282 325 247 301 219 316 225 270 280 292 290 335 337 328 415 335 432 371 418 374 444 394 251 277 234 271 225 265 212 290 227 300 256 301 250.5 306 243 328 246 337 314 367 315 351 326 355 327 350 328 342.5 336 339 336 334 331 335 371 330 371 333 388.5 330.5 411 327.5 419 344 411 343 394 346 342 342 342 348 325 372 315 374 342 372 345 382 348.5 380.5 351 377 348 369 370 363 371 353 354 374 363 382.5 357 387 351 382 369 388 335 395 381 381 391 375 392 366 395 361 398 362 401 359 405 360 410 355 408 350 415 351 418 347 422 354 418.5 356 405.5 364.5 405 368 409 370 417 364 420 370 424 372 438 368 438.5 373 434 376 438 385 440 392 447 392 448 381 444.5 383 441 385 440.5 381.5 445 380 444 360 ]; xla=[1 75 1 78 2 44 3 45 3 65 4 39 4 63 5 49 5 50 6 59 7 32 7 47 8 9 8 47 9 35 10 34 11 22 11 26 12 25 12 471 14 21 15 7 15 31 16 14 16 38 17 40 17 42 17 81 18 81 18 83 19 79 20 86 21 22 22 372 22 13 23 13 23 383 24 13 24 25 25 11 26 27 26 10 27 12 28 29 28 15 29 30 30 7 30 48 31 32 31 34 32 33 33 34 33 8 34 9 35 45 36 35 36 37 36 16 36 39 37 7 38 39 38 41 39 40 40 2 41 17 41 92 42 43 43 2 43 72 44 3 45 46 46 8 46 55 47 48 47 6 47 5 48 61 49 50 49 53 50 51 51 52 51 59 52 56 53 52 53 54 54 55 54 63 55 3 56 57 57 58 57 60 57 4 58 59 60 62 61 60 62 4 62 85 63 64 64 65 64 76 65 66 66 67 66 76 67 44 67 68 68 69 68 75 69 70 69 71 69 1 70 2 70 43 71 72 71 74 72 73 73 74 73 18 74 1 74 80 75 76 76 77 77 78 77 19 78 79 79 80 80 18 81 82 82 83 82 90 83 84 84 85 85 20 86 87 86 88 87 88 87 92 88 89 88 91 89 20 89 84 89 90 90 91 91 92 ]; for i=143:-1:1 if xla(i,2)>92 xla(i,:)=[]; end end a=ones(92,92)*inf; for i=1:92 a(i,i)=0; end for k=1:140 i=xla(k,1);j=xla(k,2); sss=sqrt((zb(i,1)-zb(j,1))^2+(zb(i,2)-zb(j,2))^2); a(i,j)=sss; a(j,i)=sss; end 这段代码用的是Floyd-Warshall算法还是Floyd算法

最新推荐

recommend-type

java经典面试2010集锦100题(不看你后悔)

JAVA试题(100道) —————————————————————————————————————— 题目1: 下面不属于基本类型的是:c (选择1项) A) boolean B) long C) String D) byte 题目2:d 如下程序中:...
recommend-type

WWTO,小程序跨端迁移解决方案,低成本将微信小程序转为其他平台(百度、支付宝、头条)小程序 .zip

WWTO,小程序跨端迁移解决方案,低成本将微信小程序转为其他平台(百度、支付宝、头条)小程序。世贸组织 wwto : wuba 微信小程序转至其他小程序简介wwto是一款支持将原生微信小程序转换成其他小程序的工具集合。使用wwto,几乎不需要对已有的微信小程序做任何改动,可以接近零成本获得百度小程序、支付宝小程序、头条小程序。前提节点 >= 8.9.3gulp >= 4.0.0安装 npm i wwto -g #or yarn global add wwto使用**注意**如果包含插件,请将插件的源码拷贝到src/plugins/xxx目录下,xxx为被调用插件名称。命令行 # 查看帮助 wwto --help # 查看转换命令使用说明 wwto build --help # 查看源码兼容性检测使用说明 wwto lint --help # 查看版本号 wwto -v # 转换成百度小程序 wwto build -p baidu -s src -t dist/baidu # 检测源码对百
recommend-type

模拟MMMk排队模型的Matlab代码.rar

1.版本:matlab2014/2019a/2024a 2.附赠案例数据可直接运行matlab程序。 3.代码特点:参数化编程、参数可方便更改、代码编程思路清晰、注释明细。 4.适用对象:计算机,电子信息工程、数学等专业的大学生课程设计、期末大作业和毕业设计。
recommend-type

Python中快速友好的MessagePack序列化库msgspec

资源摘要信息:"msgspec是一个针对Python语言的高效且用户友好的MessagePack序列化库。MessagePack是一种快速的二进制序列化格式,它旨在将结构化数据序列化成二进制格式,这样可以比JSON等文本格式更快且更小。msgspec库充分利用了Python的类型提示(type hints),它支持直接从Python类定义中生成序列化和反序列化的模式。对于开发者来说,这意味着使用msgspec时,可以减少手动编码序列化逻辑的工作量,同时保持代码的清晰和易于维护。 msgspec支持Python 3.8及以上版本,能够处理Python原生类型(如int、float、str和bool)以及更复杂的数据结构,如字典、列表、元组和用户定义的类。它还能处理可选字段和默认值,这在很多场景中都非常有用,尤其是当消息格式可能会随着时间发生变化时。 在msgspec中,开发者可以通过定义类来描述数据结构,并通过类继承自`msgspec.Struct`来实现。这样,类的属性就可以直接映射到消息的字段。在序列化时,对象会被转换为MessagePack格式的字节序列;在反序列化时,字节序列可以被转换回原始对象。除了基本的序列化和反序列化,msgspec还支持运行时消息验证,即可以在反序列化时检查消息是否符合预定义的模式。 msgspec的另一个重要特性是它能够处理空集合。例如,上面的例子中`User`类有一个名为`groups`的属性,它的默认值是一个空列表。这种能力意味着开发者不需要为集合中的每个字段编写额外的逻辑,以处理集合为空的情况。 msgspec的使用非常简单直观。例如,创建一个`User`对象并序列化它的代码片段显示了如何定义一个用户类,实例化该类,并将实例序列化为MessagePack格式。这种简洁性是msgspec库的一个主要优势,它减少了代码的复杂性,同时提供了高性能的序列化能力。 msgspec的设计哲学强调了性能和易用性的平衡。它利用了Python的类型提示来简化模式定义和验证的复杂性,同时提供了优化的内部实现来确保快速的序列化和反序列化过程。这种设计使得msgspec非常适合于那些需要高效、类型安全的消息处理的场景,比如网络通信、数据存储以及服务之间的轻量级消息传递。 总的来说,msgspec为Python开发者提供了一个强大的工具集,用于处理高性能的序列化和反序列化任务,特别是当涉及到复杂的对象和结构时。通过利用类型提示和用户定义的模式,msgspec能够简化代码并提高开发效率,同时通过运行时验证确保了数据的正确性。"
recommend-type

管理建模和仿真的文件

管理Boualem Benatallah引用此版本:布阿利姆·贝纳塔拉。管理建模和仿真。约瑟夫-傅立叶大学-格勒诺布尔第一大学,1996年。法语。NNT:电话:00345357HAL ID:电话:00345357https://theses.hal.science/tel-003453572008年12月9日提交HAL是一个多学科的开放存取档案馆,用于存放和传播科学研究论文,无论它们是否被公开。论文可以来自法国或国外的教学和研究机构,也可以来自公共或私人研究中心。L’archive ouverte pluridisciplinaire
recommend-type

STM32 HAL库函数手册精读:最佳实践与案例分析

![STM32 HAL库函数手册精读:最佳实践与案例分析](https://khuenguyencreator.com/wp-content/uploads/2020/07/bai11.jpg) 参考资源链接:[STM32CubeMX与STM32HAL库开发者指南](https://wenku.csdn.net/doc/6401ab9dcce7214c316e8df8?spm=1055.2635.3001.10343) # 1. STM32与HAL库概述 ## 1.1 STM32与HAL库的初识 STM32是一系列广泛使用的ARM Cortex-M微控制器,以其高性能、低功耗、丰富的外设接
recommend-type

如何利用FineReport提供的预览模式来优化报表设计,并确保最终用户获得最佳的交互体验?

针对FineReport预览模式的应用,这本《2020 FCRA报表工程师考试题库与答案详解》详细解读了不同预览模式的使用方法和场景,对于优化报表设计尤为关键。首先,设计报表时,建议利用FineReport的分页预览模式来检查报表的布局和排版是否准确,因为分页预览可以模拟报表在打印时的页面效果。其次,通过填报预览模式,可以帮助开发者验证用户交互和数据收集的准确性,这对于填报类型报表尤为重要。数据分析预览模式则适合于数据可视化报表,可以在这个模式下调整数据展示效果和交互设计,确保数据的易读性和分析的准确性。表单预览模式则更多关注于表单的逻辑和用户体验,可以用于检查表单的流程是否合理,以及数据录入
recommend-type

大学生社团管理系统设计与实现

资源摘要信息:"基于ssm+vue的大学生社团管理系统.zip" 该系统是基于Java语言开发的,使用了ssm框架和vue前端框架,主要面向大学生社团进行管理和运营,具备了丰富的功能和良好的用户体验。 首先,ssm框架是Spring、SpringMVC和MyBatis三个框架的整合,其中Spring是一个全面的企业级框架,可以处理企业的业务逻辑,实现对象的依赖注入和事务管理。SpringMVC是基于Servlet API的MVC框架,可以分离视图和模型,简化Web开发。MyBatis是一个支持定制化SQL、存储过程以及高级映射的持久层框架。 SpringBoot是一种全新的构建和部署应用程序的方式,通过使用SpringBoot,可以简化Spring应用的初始搭建以及开发过程。它使用了特定的方式来进行配置,从而使开发人员不再需要定义样板化的配置。 Vue.js是一个用于创建用户界面的渐进式JavaScript框架,它的核心库只关注视图层,易于上手,同时它的生态系统也十分丰富,提供了大量的工具和库。 系统主要功能包括社团信息管理、社团活动管理、社团成员管理、社团财务管理等。社团信息管理可以查看和编辑社团的基本信息,如社团名称、社团简介等;社团活动管理可以查看和编辑社团的活动信息,如活动时间、活动地点等;社团成员管理可以查看和编辑社团成员的信息,如成员姓名、成员角色等;社团财务管理可以查看和编辑社团的财务信息,如收入、支出等。 此外,该系统还可以通过微信小程序进行访问,微信小程序是一种不需要下载安装即可使用的应用,它实现了应用“触手可及”的梦想,用户扫一扫或者搜一下即可打开应用。同时,它也实现了应用“用完即走”的理念,用户不用关心是否安装太多应用的问题。应用将无处不在,随时可用,但又无需安装卸载。 总的来说,基于ssm+vue的大学生社团管理系统是一款功能丰富、操作简便、使用方便的社团管理工具,非常适合大学生社团的日常管理和运营。
recommend-type

"互动学习:行动中的多样性与论文攻读经历"

多样性她- 事实上SCI NCES你的时间表ECOLEDO C Tora SC和NCESPOUR l’Ingén学习互动,互动学习以行动为中心的强化学习学会互动,互动学习,以行动为中心的强化学习计算机科学博士论文于2021年9月28日在Villeneuve d'Asq公开支持马修·瑟林评审团主席法布里斯·勒菲弗尔阿维尼翁大学教授论文指导奥利维尔·皮耶昆谷歌研究教授:智囊团论文联合主任菲利普·普雷教授,大学。里尔/CRISTAL/因里亚报告员奥利维耶·西格德索邦大学报告员卢多维奇·德诺耶教授,Facebook /索邦大学审查员越南圣迈IMT Atlantic高级讲师邀请弗洛里安·斯特鲁布博士,Deepmind对于那些及时看到自己错误的人...3谢谢你首先,我要感谢我的两位博士生导师Olivier和Philippe。奥利维尔,"站在巨人的肩膀上"这句话对你来说完全有意义了。从科学上讲,你知道在这篇论文的(许多)错误中,你是我可以依
recommend-type

STM32 HAL库深度解析:新手到高手的进阶之路

![STM32 HAL库深度解析:新手到高手的进阶之路](https://img-blog.csdnimg.cn/20210526014326901.png?x-oss-process=image/watermark,type_ZmFuZ3poZW5naGVpdGk,shadow_10,text_aHR0cHM6Ly9ibG9nLmNzZG4ubmV0L2xjemRr,size_16,color_FFFFFF,t_70) 参考资源链接:[STM32CubeMX与STM32HAL库开发者指南](https://wenku.csdn.net/doc/6401ab9dcce7214c316e8df