gpt4 book ai didi

python - 使用内存但代码仍然永远运行

转载 作者:太空狗 更新时间:2023-10-29 15:36:27 25 4
gpt4 key购买 nike

我正在尝试解决 SPOJ 问题“Cricket Tournament”。我用 python 和 c 编写了代码。在 python 中,输入 0.0 0/0 300 大约需要 2 秒。但在 C 中它会永远运行。 C 中的代码正在运行一些较小的测试用例,例如 19.5 0/0 1

Code in C

#include<stdio.h>
float ans[10][120][300]={0};
float recursion(int balls, int reqRuns, int wickets);
int readScore(void);

int main()
{
int t;
scanf("%d",&t);
while(t--)
{
memset(ans,0,sizeof(ans));
float overs;
int myruns,wickets,target;
scanf("%f",&overs);
myruns=readScore();
scanf("%d",&wickets);
//printf("%d %d\n",myruns,wickets );
scanf("%d",&target);
//printf("%d %d %d\n",myruns,wickets,target);
if(myruns>=target)
{
printf("%s\n","100.00");
continue;
}
else if(wickets>=10)
{
printf("%s\n", "0.00");
continue;
}
printf("overs = %f\n", overs);
int ov = (int) overs;
int ball = (int)(overs*10)%10;
int totballs = 6*ov+ball;
//printf("%d %d\n",ov,ball );
//printf("%d %d %d\n",totballs, target- myruns,wickets );
float finalAns = recursion(totballs,target-myruns, wickets)*100;
printf("%.2f\n",finalAns);

}
return 0;
}

int readScore()
{
char ch;
int ans2=0;
ch = getchar();
//ch = getchar();
//ans = ans*10 + ch-'0';
//printf("sadasdas %d\n",ch );
while(ch!='/')
{
ch=getchar();
//printf(" ch = %d\n", ch-'0');
if(ch!='/')
ans2 = ans2*10 + ch-'0';

}
//printf("%d\n",ans );
return ans2;
}

float recursion(int balls, int reqRuns, int wickets)
{
if (reqRuns<=0)
return 1;
if (balls==120||wickets==10)
return 0;
if(ans[wickets][balls][reqRuns]!=0)
return ans[wickets][balls][reqRuns];

ans[wickets][balls][reqRuns] = (recursion(balls+1, reqRuns,wickets)+recursion(balls+1, reqRuns-1,wickets)+
recursion(balls+1, reqRuns-2,wickets)+recursion(balls+1, reqRuns-3,wickets)+
recursion(balls+1, reqRuns-4,wickets)+recursion(balls+1, reqRuns-5,wickets)+
recursion(balls+1, reqRuns-6,wickets)+recursion(balls+1, reqRuns,wickets+1)+
2*recursion(balls, reqRuns-1,wickets))/10;
return ans[wickets][balls][reqRuns];
}

Code in Python

from __future__ import division

saved = {}
t = input()

def func(f):
if f in saved: return saved[f]
x,y,z,n = f
if z >= n: return 1
if x == 120: return 0
if y == 10: return 0

saved[f] = (func((x+1,y+1,z,n)) + func((x+1, y,z,n)) + func((x+1,y,z+1,n)) + func((x+1, y, z+2,n)) + func((x+1, y, z+3,n)) + func((x+1, y, z+4,n)) + func((x+1, y, z+5,n))+ func((x+1, y, z+6,n))+ func((x,y,z+1,n)) + func((x,y,z+1,n))) / 10
return saved[f]

def converter(f):
v = f.index('.')
x,y = int(f[:v]), int(f[-1])
return x*6+(y)

for i in range(t):
x,y,z = raw_input().split()
v = y.index('/')
q = int(y[:v])
x,y,z = converter(x), int(y[(v+1):]), int(z)
print '%.2f' % (100 * func((x,y,q,z)))

最佳答案

你的问题是很多递归的结果都是0,所以

if(ans[wickets][balls][reqRuns]!=0)
return ans[wickets][balls][reqRuns];

在许多情况下无法返回缓存的结果,因此您要重新计算许多结果,而在 Python 中检查 f in saved 会阻止重新计算相同的值.

我更改了你的 C 代码以将 ans 的初始条目设置为包含负数(如果你知道你的平台的浮点表示是 IEEE754,只需更改为 memset(ans , 0x80, sizeof ans); 将执行), 并将条件替换为

if (ans[wickets][balls][reqRuns] >= 0)

并立即得到结果:

$ time ./a.out  < spoj_inp.txt 
overs = 0.000000
18.03

real 0m0.023s
user 0m0.020s
sys 0m0.002s

关于python - 使用内存但代码仍然永远运行,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/12678715/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com