文章目录
本关任务: 相传古印度宰相达依尔,是国际象棋的发明者。 有一次,国王因为他的贡献要奖励他,问他想要什么.达依尔说:”只要在国际象棋棋盘上(共64格)摆上这么些麦子就行了:第一格一粒,第二格两粒,……,后面一格的麦子总是前一格一麦子数的两倍,摆满整个棋盘,我就感恩不尽了。 编写程序,根据输入的格子数,计算国王要付给达依尔的麦子数。
输入n值 处理 s初值为0(累计的麦子数) x初值为1(格子上的麦子数) 循环n次 每次将麦子数x累加到s中 x赋值为x的2倍 输出s值
为了完成本关任务,你需要掌握: for循环
在python中,对于for循环,可以设置遍历结构为range函数 for i in range(初值,终值): <语句块>
i从初值取值到终值-1,每次执行一次循环体
平台会对你编写的代码进行测试:
测试输入:6 预期输出: 麦子数63
测试输入:1; 预期输出: 麦子数1
测试输入:10; 预期输出: 麦子数1023
n = eval(input())
# 代码开始
s = 1 # 累计的麦子数
x = 1 # 格子上的麦子数
for i in range(x, n):
x = x * 2
s = s + x;
print('麦子数%d' % s, end='')
# 代码结束
本关任务: 大学英语四级考试,即CET-4,College English Test Band 4的缩写,是由国家教育部高等教育司主持的全国性英语考试。 英语四级大纲要求的词汇量是4500个词,是英语备考的关键。 《四级词汇.txt》文件如图所示,每行显示一个单词及其中文释义。
编写一个程序,输入一个单词(英文或中文),将所有包含该单词的行显示出来,并统计共有几个。 若该单词不存在,则显示没有此单词。 
1.输入需要查询的单词,计数器置0 2.打开文件,对文件每行遍历 若该行包含需要查询的单词,则输出该行,计算器加一 3.文件遍历结束后,若计数器为0,输出没有查询结果,否则输出计数器的值 4.关闭文件

为了完成本关任务,你需要掌握:1.如何处理文件,2.如何对文件循环。
语法格式: <file对象名>=open(<文件名>,<打开模式>,<encoding=编码格式>) Python内置的open()函数打开一个文件,创建一个file对象。 文件名是字符型数据。 若文件在当前文件夹下,直接输入文字的名字,若在其他文件夹下,还需写出文件的路径。 打开模式有只读(“r”),写入(“w”),追加(“a”)等。 默认文件访问模式为只读®。 以只读方式打开文件,只能读取文件的内容,不能修改文件。 只读方式打开文件,文件的指针将会放在文件的开头。
for <循环变量> in 文件 : <循环体> 从文件的第一行到文件的最后一行,依次读取每行的文字到循环变量,执行循环体后,读取下一行
<file对象名>.close() 对文件处理完成以后,使用文件对象.close()方法来关闭文件。
语法格式: for <循环变量> in 文件 : <循环体> 从文件的第一行到文件的最后一行,依次读取每行的文字到循环变量,执行循环体后,读取下一行
平台会对你编写的代码进行测试:
测试输入:天空 预期输出: heaven n.天堂;天,天空 sky n.天,天空 共有2个单词
测试输入:sky 预期输出: sky n.天,天空 whisky n.威士忌酒 共有2个单词
测试输入:sky 预期输出: sky n.天,天空 whisky n.威士忌酒 共有2个单词
测试输入:syk 预期输出: 没有此单词
word = input("输入单词")
f1 = open("sy5//四级词汇.txt", "r")
s = 0
# 代码开始
for i in f1:
if i.find(word) != -1:
s += 1
print(i, end='')
if s != 0:
print('共有%d个单词' % s, end='')
else:
print("没有此单词")
f1.close()
# 代码结束
某地出租车计费程序,规则如下: 白天起步2公里内8元,2公里以上续程单价每公里为2.0元, 夜间(22:00一次日5:30)2公里内10元,2公里以上续程单价每公里为2.40元。 此外,还要附加低速计时收费。在时速12公里/小时(含12公里/小时)以下,累计每满2分钟计费1元。 本官任务:编写程序,输入打车的时间,公里数和低速行驶的时间(分钟),计算车费。要求能循环计算 示例如下: 请输入打车时间(小时:分钟)9:0 请输入里程5 请输入低速行驶时间(分钟)10 车费是19.00元 是否继续(y/n)y 请输入打车时间(小时:分钟)22:15 请输入里程6 请输入低速行驶时间(分钟)1 车费是19.60元 是否继续(y/n)n
1.循环变量初值为y 2.如果循环变量为y或Y,则执行下列操作 3.输入打车的时间:小时和分钟、里程和低速运行时间 4.根据小时和分钟,判断是白天还是夜间 如果是白天,如果里程小于2,运费是8元,否则是8+(里程-2)*2 如果是夜晚,如果里程小于2,运费是10元,否则是10+(里程-2)*2.4 5.运费加上低速运行时间除以2的整数 6.输出运费 7.输入循环变量,决定是否继续循环 
为了完成本关任务,你需要掌握:1.如何循环计算,2.如何判断白天或晚上,3.如何计算低速运行费用。


在计算里程费用之后,加上低速运行时间除以2的整数 f=f+d//2
平台会对你编写的代码进行测试:
示例输入输出:
请输入打车时间(小时:分钟)10:30 请输入里程10 请输入低速行驶时间(分钟)7 车费是27.00元 是否继续(y/n)y 请输入打车时间(小时:分钟)22:30 请输入里程10 请输入低速行驶时间(分钟)2 车费是30.20元 是否继续(y/n)n
# 代码开始
jx = "y"
f = 0
while jx == "y" or jx == "Y":
s = input("请输入打车时间(小时:分钟)")
l = float(input("请输入里程"))
d = float(input("请输入低速行驶时间(分钟)"))
h = eval(s[:s.find(":")])
m = eval(s[s.find(":") + 1:])
if h < 5 or (h == 5 and m < 30) or h >= 22:
if l < 2:
f = 10
else:
f = 10 + (l - 2) * 2.4
else:
if l < 2:
f = 8
else:
f = 8 + (l - 2) * 2
print("车费是%0.2f元" %(int(f + d / 2)))
jx = input("是否继续(y/n)")
# 代码结束
本关任务: 编写程序,从键盘输入x的值,根据麦克劳林级数求正弦值,直到最后一项绝对值小于le−7(即10−7)为止 (注:x为弧度值) 
1.设置循环变量初值 分子 fz=x 分母fm=1 项数i=1求和项s=0 2.当符合循环条件 abs(fz/fm)>=1e-7 3.执行递推关系 s=s+fz/fm fz=fz*(-x)x fm=fm2i(2*i+1) i=i+1 
平台会对你编写的代码进行测试: 测试输入 输入x3.14 输出 sin(3.14)=0.00
输入1.05 输出 sin(1.05)=0.87
参考答案
import math
x = eval(input("输入x"))
# 代码开始
fz = x
fm = 1
s = 0
n = 1
while abs(fz / fm) >= 1e-7:
s = s + fz / fm
fz = -x * x * fz
fm = fm * (2 * n) * (2 * n + 1)
n = n + 1
print("sin(%.2f)=%.2f" % (x, s))
# 代码结束
素数,就是除了1和它自身外,再没有其它因子的自然数。 编写程序,输入一个整数,判断其是否为素数。 
输入:输入整数x 处理:i从2循环到x-1,若x%i为0,则显示不是素数,退出循环 若循环正常结束,则显示是素数 
为了完成本关任务,你需要掌握: 1.break 2.循环的扩展模式
break常用于循环语句体内,某一个if条件分支的语句中。用来表示在循环过程中,满足某一条件时,结束循环。
for <循环变量> in <遍历结构>: <语句块1> else: <语句块2> 在<语句块1>中,通常有带有if<条件>的break语句。如果在循环过程中,出现符合<条件>的情况,则break退出循环,不会执行else中的语句块2。 如果循环执行完,一直没有符合if后面的<条件>。当for循环执行之后,程序会执行else后面的<语句块2>。
平台会对你编写的代码进行测试:
测试输入: 请输入一个整数10 预期输出: 10不是素数
测试输入: 请输入一个整数17 预期输出: 17是素数
import math
x = eval(input("请输入一个整数"))
# 代码开始
i = int(math.sqrt(x))
for i in range(2, x):
if x % i == 0:
print("%d不是素数"%x,end="")
break # 可以整除,肯定不是素数,结束循环
else:
print("%d是素数"%x,end="")
# 代码结束
本关任务: 从键盘输入若干个1-100之间的整数,求这些数的和、个数、平均值、最大值、最小值。 若输入0,则输入结束,显示统计结果。若输入不符合要求的数,则显示输入错误,并不将该数计算在内。 
1.设置zd变量存放最大值,初值为0。
zx变量存放最小值,初值为100。 s变量存放求和,c变量存放个数。 2.永真循环 输入整数, 若此数为零,退出循环; 若此数为负数或大于100或不是整数,重新输入; 若此数小于zx,则zx赋值为此数 若此数大于zd,则zd赋值为此数 计数器加1。累加器累加此数。 3.退出循环后,输出结果 
1.多变量同时赋值 2.永真循环 3.continue 4.最大值、最小值算法
赋值语句可以对多变量同时赋值。 变量1被赋值为表达式1,变量2被赋值为表达式2…… 例如,如果要对a赋值为1,b赋值为0,可以执行a,b=1,0。 也可以直接交换a、b变量的值,执行a,b=b,a后,a为0,b为1。
while True: <循环体> 永真循环是指循环条件为True的循环,无条件重复执行循环体。 在循环体里,有分支语句,符合条件则通过break语句退出循环。 在执行循环时,需要能满足退出条件,否则就会成为死循环。
常用于循环语句体内某一个if条件分支的语句中, 满足某一条件时,结束本轮循环,提前进入下一轮循环。 while语句遇到continue时,程序会立刻转到条件表达式,开始下一轮循环; 而在for语句中遇到continue时,程序会立刻更新循环变量,开始下一轮循环。
最大值 在循环之前,将最大值变量设置为最小可能的值。 例如,输入数值是1-100之间,将其设置为1。 在循环过程中,一旦发现输入的数大于该变量的值,就将该变量的值设置为该值。 zd=<初值> while <循环条件>: x=input() if x>zd: zd=x 最小值 在循环之前,将最小值变量设置为最大可能的值。 例如,数值范围是1-100之间,将其设置为100。 在循环过程中,一旦发现输入的数小于该变量的值,就将该变量的值设置为该值。 zx=<初值> while <循环条件>: x=input() if x<zx: zx=x
平台会对你编写的代码进行测试:
预期输入
请输入一个整数(1-100)7 请输入一个整数(1-100)9 请输入一个整数(1-100)20 请输入一个整数(1-100)200 输入错误 请输入一个整数(1-100)0
预期输出 有效数3个,和36,平均值12.0,最大值20,最小值7
# 代码开始
i = 1
zd = 0 # 最大值
zx = 100 # 最小值
a = 0 # 平均值
s = 0 # 和
c = 0 # 有效个数
# zd, zx, a, s, c = 0, 100, 0, 0, 0 # 多变量同时赋值
while True:
i = int(input("请输入一个整数(1-100)"))
if 100 >= i >= 1:
c += 1
s += i
a = s / c
if i < zx:
zx = i
if i > zd:
zd = i
elif i == 0:
print("有效数%d个,和%d,平均值%.1f,最大值%d,最小值%d" % (c, s, a, zd, zx), end="")
break
else:
print("输入错误")
continue
# 代码结束
1、执行下列程序后,输出结果是
x=“hunan university”
for c in x:
if c==“n”:
continue
print(c,end=“”)
A、hu
B、hua uiversity
C、nnn
D、hunan university
2、x=“hunan university”
for c in x:
if c==“n”:
break
print(c,end=“”)
A、hu
B、hua university
C、nnn
D、hunan university
3、程序代码如下所示
s= 0
while True:
k = eval(input(‘请输入0退出:’))
if k==0:
break
elif k<0:
continue
elif k>0:
s=s+k
s=s+1
print(s)
若用户依次输入 3 2 -5 1 0
则程序的输出是
A、1
B、6
C、10
D、9
4、c= 0
while True:
k = eval(input(‘请输入0退出:’))
if k>0:
continue
elif k<0:
c=c+1
elif k==0:
break
c=c+1
print©
依次输入 10 -20 30 -40 -60 0
输出结果是
A、6
B、3
C、-120
D、5
5、while True:
guess = eval(input())
if guess == 100//2:
break
作为输入能够结束程序运行的是
A、50
B、100
C、2
D、“100//2”
6、for count in range(10) 循环执行多少次
A、9
B、10
C、11
D、无限次
7、执行以下程序,输入”93python22”,输出结果是:
w = input(‘请输入数字和字母构成的字符串:’)
for x in w:
if ‘0’<= x <= ‘9’:
continue
else:
w.replace(x,‘’)
print(w)
A、python9322
B、python
C、93python22
D、9322
8、下面代码的输出结果是
sum = 1.0
for num in range(1,4):
sum+=num
print(sum)
A、6
B、7.0
C、1.0
D、7
9、下面代码的输出结果是
for i in range(10):
if i%2==0:
continue
else:
print(i, end=“,”)
A、2,4,6,8,
B、0,2,4,6,8,
C、0,2,4,6,8,10,
D、1,3,5,7,9,
10、以下程序的输出结果是:
x=10
while x:
x-=1
if not x%2:
print(x,end = ‘’)
A、86420
B、975311
C、 97531
D、864200
关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭4年前。Improvethisquestion我想在固定时间创建一系列低音和高音调的哔哔声。例如:在150毫秒时发出高音调的蜂鸣声在151毫秒时发出低音调的蜂鸣声200毫秒时发出低音调的蜂鸣声250毫秒的高音调蜂鸣声有没有办法在Ruby或Python中做到这一点?我真的不在乎输出编码是什么(.wav、.mp3、.ogg等等),但我确实想创建一个输出文件。
我想将html转换为纯文本。不过,我不想只删除标签,我想智能地保留尽可能多的格式。为插入换行符标签,检测段落并格式化它们等。输入非常简单,通常是格式良好的html(不是整个文档,只是一堆内容,通常没有anchor或图像)。我可以将几个正则表达式放在一起,让我达到80%,但我认为可能有一些现有的解决方案更智能。 最佳答案 首先,不要尝试为此使用正则表达式。很有可能你会想出一个脆弱/脆弱的解决方案,它会随着HTML的变化而崩溃,或者很难管理和维护。您可以使用Nokogiri快速解析HTML并提取文本:require'nokogiri'h
我脑子里浮现出一些关于一种新编程语言的想法,所以我想我会尝试实现它。一位friend建议我尝试使用Treetop(Rubygem)来创建一个解析器。Treetop的文档很少,我以前从未做过这种事情。我的解析器表现得好像有一个无限循环,但没有堆栈跟踪;事实证明很难追踪到。有人可以指出入门级解析/AST指南的方向吗?我真的需要一些列出规则、常见用法等的东西来使用像Treetop这样的工具。我的语法分析器在GitHub上,以防有人希望帮助我改进它。class{initialize=lambda(name){receiver.name=name}greet=lambda{IO.puts("He
我有多个ActiveRecord子类Item的实例数组,我需要根据最早的事件循环打印。在这种情况下,我需要打印付款和维护日期,如下所示:ItemAmaintenancerequiredin5daysItemBpaymentrequiredin6daysItemApaymentrequiredin7daysItemBmaintenancerequiredin8days我目前有两个查询,用于查找maintenance和payment项目(非排他性查询),并输出如下内容:paymentrequiredin...maintenancerequiredin...有什么方法可以改善上述(丑陋的)代
我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("
给定一个复杂的对象层次结构,幸运的是它不包含循环引用,我如何实现支持各种格式的序列化?我不是来讨论实际实现的。相反,我正在寻找可能会派上用场的设计模式提示。更准确地说:我正在使用Ruby,我想解析XML和JSON数据以构建复杂的对象层次结构。此外,应该可以将该层次结构序列化为JSON、XML和可能的HTML。我可以为此使用Builder模式吗?在任何提到的情况下,我都有某种结构化数据-无论是在内存中还是文本中-我想用它来构建其他东西。我认为将序列化逻辑与实际业务逻辑分开会很好,这样我以后就可以轻松支持多种XML格式。 最佳答案 我最
这个问题在这里已经有了答案:关闭10年前。PossibleDuplicate:Pythonconditionalassignmentoperator对于这样一个简单的问题表示歉意,但是谷歌搜索||=并不是很有帮助;)Python中是否有与Ruby和Perl中的||=语句等效的语句?例如:foo="hey"foo||="what"#assignfooifit'sundefined#fooisstill"hey"bar||="yeah"#baris"yeah"另外,类似这样的东西的通用术语是什么?条件分配是我的第一个猜测,但Wikipediapage跟我想的不太一样。
什么是ruby的rack或python的Java的wsgi?还有一个路由库。 最佳答案 来自Python标准PEP333:Bycontrast,althoughJavahasjustasmanywebapplicationframeworksavailable,Java's"servlet"APImakesitpossibleforapplicationswrittenwithanyJavawebapplicationframeworktoruninanywebserverthatsupportstheservletAPI.ht
华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o
我想解析一个已经存在的.mid文件,改变它的乐器,例如从“acousticgrandpiano”到“violin”,然后将它保存回去或作为另一个.mid文件。根据我在文档中看到的内容,该乐器通过program_change或patch_change指令进行了更改,但我找不到任何在已经存在的MIDI文件中执行此操作的库.他们似乎都只支持从头开始创建的MIDI文件。 最佳答案 MIDIpackage会为您完成此操作,但具体方法取决于midi文件的原始内容。一个MIDI文件由一个或多个音轨组成,每个音轨是十六个channel中任何一个上的