所以我试着测试一下是否是回文。这是我的代码:
此函数返回较大字符串前半部分的字符串。 (“TEST”返回“TE”,“HELLO”返回“HE”)
def takeStart(s):
start = ""
# The following determines the final index of the first half
if len(s)%2==0:
a = (len(s)/2)-1
else:
a = ((len(s)-1)/2)-1
for i in range(a):
start+=s[i]
return start
此函数返回较大字符串后半部分的字符串。 (“TEST”返回“ST”,“HELLO”返回“LO”)
def takeEnd(s):
end = ""
# The following determines the beginning index of the second half
if len(s)%2==0:
a = (len(s)/2)
else:
a = ((len(s)-1)/2)
for i in range(a,len(s)):
end+=s[i]
return end
此函数翻转一个字符串。 (“TEST”返回“TSET”,“HELLO”返回“OLLEH”)
def flip(s):
flipped = ""
for i in range(1,len(s)):
flipped+=s[len(s)-i]
flipped+=s[0]
return flipped
此代码采用两个3位数字的每个乘积,并检查它是否是回文
for i in range(100,1000):
for q in range(100,1000):
a = i*q
if takeStart(str(a)) == flip(takeEnd(str(a))):
print(str(a))
运行此代码时,输出:
Traceback (most recent call last):
File "[redacted]", line 39, in <module>
if takeStart(str(a)) == flip(takeEnd(str(a))):
File "[redacted]", line 14, in takeStart
for i in range(a):
TypeError: 'float' object cannot be interpreted as an integer
好吧,我以为我只是将a转换为整数,所有都应该膨胀。
这样做似乎可以删除所有错误,但无任何输出。 (每隔一段时间就有新行,这让我觉得它有效,但没有输出任何数据)
关于为什么会发生这种情况的任何想法?
更新:我的代码现在:
def takeStart(s):
start = ""
if len(s)%2==0:
a = (len(s)//2)
else:
a = (len(s)-1)//2
return start[0:a]
def takeEnd(s):
end = ""
if len(s)%2==0:
a = (len(s)//2)
else:
a = ((len(s)-1)//2)
return end[int(a):len(s)]
def flip(s):
return s[::-1]
for i in range(100,1000):
for q in range(100,1000):
a = i*q
if takeStart(str(a)) == flip(takeEnd(str(a))):
print(str(a))
这只是输出每一个数字。 我测试了每个方法,他们返回空字符串。 (我假设),这就是为什么每个数字都通过回文检查和打印。
答案 0 :(得分:10)
首先,使用range(int(a))
和range(int(a), len(s))
将解决您的错误。正如Jon Clements指出的那样,只需使用//
而不是/
来获取整数,就可以更轻松地解决这个问题。但不管怎样,它都不会造成任何问题。
你的问题是range
和几乎所有Python相关的问题都是半开放的。因此,您的takeStart
函数会返回所有值,但不包括中间点 - 也就是说,它会为H
,HELLO
提供T
对于TEST
,BIGG
为BIGGERTEST
。
只需摆脱-1
行上的a = …
即可解决该问题。
然后它打印出一大堆输出线,所有的回文,我认为这是你打算做的。
然而,你仍然不会得到任何奇怪的回文。例如,使用“MADAM”,即使您获得正确的功能,takeStart(s)
为MA
,takeEnd(s)
为DAM
,flip(takeEnd(s))
为{{1} },这与MAD
不同。即使你的功能正常,他们也无法解决问题。因此,您的设计和实施中存在一个错误。如果你想一段时间,你应该弄清楚如何使这项工作。
而且,一旦你这样做,你应该意识到MAD
和takeStart
可以简化很多。 (提示:在哪些情况下你真的需要以不同的方式处理奇数和偶数长度?)
虽然我们在这,但是:
takeEnd
...只是一种冗长,缓慢且容易弄错的写作方式:
foo = ""
for i in range(x, y):
foo += s[i]
return foo
同样,您的整个return foo[x:y]
功能只是:
flipped
答案 1 :(得分:0)
Pythons
range()
函数不支持浮点数,但支持numpysarange()
功能可以
要使用arange()
功能,您需要安装并导入numpy
软件包。
在这里,我们将使用arange()
函数来生成一定范围的浮点数。
arange()
具有与内置range()
方法相同的签名。但是我们可以将浮点类型参数作为参数传递给该函数。
import numpy
arange (start, stop, step)
在完整的代码示例中,如下所示:
from numpy import arange
print("Float range using NumPy arange():")
print("\nTest 1:")
for i in arange(0.0, 1.0, 0.1):
print(i, end=', ')