社区讨论
求救,TLE
P1981[NOIP 2013 普及组] 表达式求值参与者 1已保存回复 0
讨论操作
快速查看讨论及其快照的属性,并进行相关操作。
- 当前回复
- 0 条
- 当前快照
- 1 份
- 快照标识符
- @lo2nxt83
- 此快照首次捕获于
- 2023/10/23 16:56 2 年前
- 此快照最后确认于
- 2023/10/23 16:56 2 年前
求救,我TLE了(80分, R109385828)
代码:
C#include <iostream>
#include <cstdio>
#include <cstdlib>
#include <cstring>
#include <cassert>
using namespace std;
const long long MAX = 1000010;
const long long P = 10000;
long long n;
char s[MAX+1];
long long dfs(long long l, long long r) {
long long x=0,y=0,z=0;
for (long long i=l;i<=r;i++) {
if (!x) {
if (s[i]=='*') y=i;
else if (s[i]=='+' || s[i]=='-') z=i;
}
}
if (z) {
return (dfs(l, z - 1) + dfs(z + 1, r)) % P;
}
if (y)
return 1ll*dfs(l,y-1) * dfs(y+1,r) % P;
else {
long long v=0;
for (long long i=l;i<=r;i++)
v = v*10+s[i]-'0';
return v;
}
}
int main() {
scanf("%s",s+1);
n = strlen(s+1);
printf("%d",dfs(1,n) % P);
return 0;
}
回复
共 0 条回复,欢迎继续交流。
正在加载回复...