鱼C论坛

 找回密码
 立即注册
查看: 6481|回复: 18

[技术交流] Python: 每日一题 53

[复制链接]
发表于 2017-5-25 15:39:41 | 显示全部楼层 |阅读模式

马上注册,结交更多好友,享用更多功能^_^

您需要 登录 才可以下载或查看,没有账号?立即注册

x
本帖最后由 ooxx7788 于 2017-5-25 15:41 编辑

我觉得这题我说的太清楚,就实在太简单了,所以尽量少说话。
89 --> 8**1 + 9**2 = 89 * 1

695 --> 6**2 + 9**3 + 5**4= 1390 = 695 * 2

46288 --> 4**3 + 6**4+ 2**5 + 8**6+ 8**7= 2360688 = 46288 * 51

dig_pow(89, 1)  return 1
dig_pow(46288, 3) return 51
如果不能返回整数,则返回-1。
test.assert_equals(dig_pow(89, 1), 1)
test.assert_equals(dig_pow(92, 1), -1)
test.assert_equals(dig_pow(46288, 3), 51)

本帖被以下淘专辑推荐:

想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复

使用道具 举报

发表于 2017-5-25 15:59:51 | 显示全部楼层
本帖最后由 冬雪雪冬 于 2017-5-25 16:23 编辑

可以是0次方吗?
----理解错题目了,还以为方次是任意的
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-25 16:15:00 | 显示全部楼层
本帖最后由 ButcherRabbit 于 2017-5-25 22:16 编辑
def dig_pow(spam,num1):
    sum1 = 0
    spam1 = str(spam)
    for each in range(0,len(spam1)):
        sum1 += int(spam1[each])**num1
        num1 += 1
    if sum1 %spam == 0:
        return sum1//spam
    else:
        return -1
print('dig_pow(89, 1)',dig_pow(89, 1))
print('dig_pow(92, 1)',dig_pow(92, 1))
print('dig_pow(46288, 3)',dig_pow(46288, 3))
def dig_pow(spam,num1):
    sum1 = 0
    spam1 = spam
    num1 = num1+len(str(spam1))-1
    for each in range(0,len(str(spam1))):
        sum1 += (spam1%10)**num1
        num1 -= 1
        spam1 = spam1//10
    if sum1 %spam == 0:
        return sum1//spam
    else:
        return -1

print('dig_pow(89, 1)',dig_pow(89, 1))
print('dig_pow(92, 1)',dig_pow(92, 1))
print('dig_pow(46288, 3)',dig_pow(46288, 3))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-25 20:44:46 | 显示全部楼层
def dig_pow(m,n):
    sum=0
    for each in str(m):
        sum+=(int(each))**n
        n+=1
    return int(sum/m)if sum%m==0 else -1
def test():
    print (dig_pow(89, 1))
    print (dig_pow(92, 1))
    print (dig_pow(46288, 3))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-26 08:45:24 | 显示全部楼层
本帖最后由 sunnychou 于 2017-5-26 09:42 编辑

思路差不多
def dig_pow(m,i):
    sum = 0
    for each in str(m):
        sum += int(each) ** i
        i += 1
    if sum % m == 0:
        return sum // m
    else:
        print(-1)
print('dig_pow(89,1)',dig_pow(89,1))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-26 08:58:43 | 显示全部楼层
我觉得这题如果不告诉你后一个数字,计算起来就比较有难度了。
比如给89,返回1,1
给46288,返回3,51
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-26 09:31:09 | 显示全部楼层
jerryxjr1220 发表于 2017-5-26 08:58
我觉得这题如果不告诉你后一个数字,计算起来就比较有难度了。
比如给89,返回1,1
给46288,返回3,51

那这个题目就有点太难了。
要能拆分原始数字,又能想出是各位数的指数和,最后还要倒除本数。这个大概就是解密的玩法了。
选题目也困难,感觉5,6kyu之间的差距有点大。像这个题目6kyu基本逻辑上面就是直的。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-26 09:44:10 | 显示全部楼层
ooxx7788 发表于 2017-5-26 09:31
那这个题目就有点太难了。
要能拆分原始数字,又能想出是各位数的指数和,最后还要倒除本数。这个大概就 ...

穷举法的程序其实不难,难的是如果幂次i非常大的话,运算会很慢,而且也有可能根本就求不出,所以我假设当i>10000就返回-1.
def dpow(n):
    i = 1
    while True:
        t = sum([int(str(n)[j])**(i + j) for j in range(len(str(n)))])
        if t % n == 0:
            return i, t // n
        else:
            i += 1
        if i > 10000:
            return -1
print(dpow(46288))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-26 10:05:14 | 显示全部楼层
怎么题目越出越简单呢~
>>> dig_pow = lambda x,y:sum((int(n)**i for i,n in enumerate(str(x),y)))//x
>>> dig_pow(89, 1)
1
>>> dig_pow(46288, 3)
51
>>> dig_pow(92, 1)
0
>>> 
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-26 10:44:52 | 显示全部楼层
SixPy 发表于 2017-5-26 10:05
怎么题目越出越简单呢~

虽然说越出越简单,不过你做的不对哦!
dig_pow(92, 1) 返回值是-1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-26 11:12:08 | 显示全部楼层
ooxx7788 发表于 2017-5-26 10:44
虽然说越出越简单,不过你做的不对哦!
dig_pow(92, 1) 返回值是-1

你定义就不对
商不是整数就应该 得0
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

 楼主| 发表于 2017-5-26 11:43:30 | 显示全部楼层
SixPy 发表于 2017-5-26 11:12
你定义就不对
商不是整数就应该 得0

这里-1表示的应该是缺损值吧。。。
不过反正就是那么个意思。
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-5-26 12:37:06 | 显示全部楼层
ooxx7788 发表于 2017-5-26 11:43
这里-1表示的应该是缺损值吧。。。
不过反正就是那么个意思。

那还不如返回None
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-7-12 19:33:19 | 显示全部楼层
就是各个位算依次指数后求和,然后除以自己得到几输出几
def dig_pow(n,k):
    result = sum([(int(i))**j for i,j in zip(str(n),range(k,k+len(str(n))))])/n
    return int(result) if result%1==0 else -1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-9-29 14:48:09 | 显示全部楼层
def dig_pow(m,n):
        n = n +len(str(m))-1
        a = m
        result = 0
        while m:
                result += (m % 10)**n
                m //= 10
                n -= 1
        return int(result//a) if result % a == 0 else -1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2017-12-4 13:56:47 | 显示全部楼层
本帖最后由 shigure_takimi 于 2017-12-4 14:02 编辑
def dig_pow(a,b):
    numberToString = str(a)
    length = len(numberToString)
    x = sum([(int(numberToString[i]))**(i+b) for i in range(length)])
    return x//a if (x/a)%1 == 0 else -1

print(dig_pow(89,1))  # 1
print(dig_pow(92,1)) # -1
print(dig_pow(46288,3))  # 51
print(dig_pow(695,2))  # 2
def dig_pow(a,b):
    return sum([(int(str(a)[i]))**(i+b) for i in range(len(str(a)))])//a if (sum([(int(str(a)[i]))**(i+b) for i in range(len(str(a)))])/a)%1 == 0 else -1

print(dig_pow(89,1))  # 1
print(dig_pow(92,1)) # -1
print(dig_pow(46288,3))  # 51
print(dig_pow(695,2))  # 2

##    把numberToString 、length、x都代入到return,也可以写成一句话,结果是一样的,但看起来就没有那么易懂了。
##    1
##    -1
##    51
##    2
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2019-9-11 18:26:32 | 显示全部楼层
import test

def dig_pow(a,b):
          num_a = str(a)
          length = len(num_a)
          result = 0
          i = b
          for each in range(length):
                    result += int(num_a[each])**i
                    i += 1
          return result / a if result %a == 0 else -1

test.assert_equals(dig_pow(89, 1), 1)
test.assert_equals(dig_pow(92, 1), -1)
test.assert_equals(dig_pow(46288, 3), 51)
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-2-29 13:01:32 | 显示全部楼层
def f_53(num, n):
    num_str = str(num)
    total = sum([int(num_str[i])**(n+i) for i in range(len(num_str))])
    return int(total / num) if total % num == 0 else -1
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

发表于 2020-9-18 21:35:53 | 显示全部楼层
def pow(n,m):
    #n 为输入值, m为平方根次数,对n的各个数字依次按m取平方根
    #将n转为str
    str_n = str(n)
    sum = 0
    for each in (str_n):
        sum += int(each)**m
        m += 1
    if sum % n == 0:
        return sum // n
    else:
        return -1

print(pow(46288, 3))
想知道小甲鱼最近在做啥?请访问 -> ilovefishc.com
回复 支持 反对

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|鱼C工作室 ( 粤ICP备18085999号-1 | 粤公网安备 44051102000585号)

GMT+8, 2025-1-18 13:54

Powered by Discuz! X3.4

© 2001-2023 Discuz! Team.

快速回复 返回顶部 返回列表