'float'对象不能解释为int,但转换为int不会产生输出

时间:2013-10-22 00:43:25

标签: python for-loop int

所以我试着测试一下是否是回文。这是我的代码:

此函数返回较大字符串前半部分的字符串。 (“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))

这只是输出每一个数字。 我测试了每个方法,他们返回空字符串。 (我假设),这就是为什么每个数字都通过回文检查和打印。

2 个答案:

答案 0 :(得分:10)

首先,使用range(int(a))range(int(a), len(s))将解决您的错误。正如Jon Clements指出的那样,只需使用//而不是/来获取整数,就可以更轻松地解决这个问题。但不管怎样,它都不会造成任何问题。

你的问题是range和几乎所有Python相关的问题都是半开放的。因此,您的takeStart函数会返回所有值,但不包括中间点 - 也就是说,它会为HHELLO提供T对于TESTBIGGBIGGERTEST

只需摆脱-1行上的a = …即可解决该问题。

然后它打印出一大堆输出线,所有的回文,我认为这是你打算做的。

然而,你仍然不会得到任何奇怪的回文。例如,使用“MADAM”,即使您获得正确的功能,takeStart(s)MAtakeEnd(s)DAMflip(takeEnd(s))为{{1} },这与MAD不同。即使你的功能正常,他们也无法解决问题。因此,您的设计和实施中存在一个错误。如果你想一段时间,你应该弄清楚如何使这项工作。

而且,一旦你这样做,你应该意识到MADtakeStart可以简化很多。 (提示:在哪些情况下你真的需要以不同的方式处理奇数和偶数长度?)


虽然我们在这,但是:

takeEnd

...只是一种冗长,缓慢且容易弄错的写作方式:

foo = ""
for i in range(x, y):
    foo += s[i]
return foo

同样,您的整个return foo[x:y] 功能只是:

flipped

答案 1 :(得分:0)

  

Pythons range()函数不支持浮点数,但支持numpys arange()   功能可以

要使用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=', ')