所以我正在尝试测试某些东西是否是回文。这是我的代码:
此函数返回一个较大字符串的前半部分的字符串。 (“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))
这只是输出每个数字。 我测试了每种方法,它们都返回空字符串。 (我假设),这就是每个数字都通过回文检查和打印的原因。
最佳答案
首先,使用 range(int(a))
和 range(int(a), len(s))
将解决您的错误。正如 Jon Clements 指出的那样,您只需使用 //
就可以更轻松地解决这个问题而不是 /
首先获得整数。但无论哪种方式,都不会造成任何问题。
你的问题是range
s,以及几乎所有与 Python 相关的东西,都是半开放的。所以,你的 takeStart
函数返回所有值,但不包括中点——也就是说,它给你 H
对于 HELLO
, T
对于 TEST
, BIGG
对于 BIGGERTEST
.
只需去掉 -1
在你的 a = …
行,这将解决该问题。
然后它打印出一大堆输出行,全是回文,我猜这就是你打算做的。
但是,您仍然不会得到任何奇数长度的回文。例如,使用“MADAM”,即使您正确使用函数,takeStart(s)
是MA
, takeEnd(s)
是DAM
, flip(takeEnd(s))
是MAD
,这与 MAD
不同.即使您的函数工作正常,它们也不能解决问题。因此,您的设计和实现中都存在错误。如果你想了一会儿,你应该弄清楚如何让它发挥作用。
而且,一旦你这样做了,你应该意识到 takeStart
和 takeEnd
可以简化很多。 (提示:在哪些情况下您真的需要区别对待奇数和偶数长度?)
当我们这样做的时候,这个:
foo = ""
for i in range(x, y):
foo += s[i]
return foo
... 只是一种冗长、缓慢且容易出错的写法:
return foo[x:y]
同样,您的整个 flipped
功能只是:
return s[::-1]
关于python - “float”对象不能解释为 int,但转换为 int 不会产生任何输出,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/19507185/