QOJ.ac
QOJ
ID | 题目 | 提交者 | 结果 | 用时 | 内存 | 语言 | 文件大小 | 提交时间 | 测评时间 |
---|---|---|---|---|---|---|---|---|---|
#658300 | #9255. Python Program | Vegetog# | AC ✓ | 76ms | 3860kb | C++20 | 4.3kb | 2024-10-19 16:36:11 | 2024-10-19 16:36:12 |
Judging History
answer
#include<bits/stdc++.h>
#define int long long
using namespace std;
using ll =long long;
void solve()
{
vector<string> a(12);
for(int i=1;i<=11;i++){
cin>>a[i];
}
// 5 9
int ans=0;
int v=0;
int l1=-1,r1=-1,t1=1;
int f1=1;
for(int i=0;i<a[5].size();i++){
if(a[5][i]=='-') f1=-1;
if('0'<=a[5][i]&&a[5][i]<='9'){
v=v*10+(a[5][i]-'0');
}else if(a[5][i]==')'||a[5][i]==','){
if(l1==-1){
l1=v;
}else if(r1==-1){
r1=v;
}else{
t1=v*f1;
}
v=0;
}
}
v=0;
int l2=-1,r2=-1,t2=1;
int f2=1;
for(int i=0;i<a[9].size();i++){
if(a[9][i]=='-') f2=-1;
if('0'<=a[9][i]&&a[9][i]<='9'){
v=v*10+(a[9][i]-'0');
}else if(a[9][i]==')'||a[9][i]==','){
if(l2==-1){
l2=v;
}else if(r2==-1){
r2=v;
}else{
t2=v*f2;
}
v=0;
}
}
bool va1=0,va2=0,va3=0;
int nd=0;
for(int i=6;i<a[9].size();i++){
if(a[9][i]==',') nd++;
if(a[3][0]==a[9][i]){
if(nd==0){
va1=1;
}else if(nd==1){
va2=1;
}else if(nd==2){
va3=1;
}
}
}
if(t1>0){
while(l1<r1){
if(va1) l2=l1;
if(va2) r2=l1;
if(va3) t2=l1;
int L,R,T;
if(t2>0){
L=l2;
R=r2-1;
if(L>R){
l1+=t1;
continue;
}
// T=t2;
int l=0,r=1e9;
while(l<r){
int mid=(l+r+1)/2;
if(L+mid*t2<=R){
l=mid;
}else{
r=mid-1;
}
}
ans+=(L+L+l*t2)*(l+1)/2;
// cout<<L<<" "<<L+l*t2<<" "<<l-1<<"\n";
}else{
L=r2+1;
R=l2;
if(L>R){
l1+=t1;
continue;
}
// T=-t2;
int l=0,r=1e9;
while(l<r){
int mid=(l+r+1)/2;
if(R+mid*t2>=L){
l=mid;
}else{
r=mid-1;
}
}
ans+=(R+R+l*t2)*(l+1)/2;
// cout<<R<<" "<<R+l*t2<<" "<<l-1<<"\n";
}
// cout<<L<<" "<<R<<"\n";
l1+=t1;
}
}else{
while(l1>r1){
if(va1) l2=l1;
if(va2) r2=l1;
if(va3) t2=l1;
int L,R,T;
if(t2>0){
L=l2;
R=r2-1;
if(L>R){
l1+=t1;
continue;
}
// T=t2;
int l=0,r=1e9;
while(l<r){
int mid=(l+r+1)/2;
if(L+mid*t2<=R){
l=mid;
}else{
r=mid-1;
}
}
ans+=(L+L+l*t2)*(l+1)/2;
// cout<<L<<" "<<L+l*t2<<" "<<l-1<<"\n";
}else{
L=r2+1;
R=l2;
if(L>R){
l1+=t1;
continue;
}
// T=-t2;
int l=0,r=1e9;
while(l<r){
int mid=(l+r+1)/2;
if(R+mid*t2>=L){
l=mid;
}else{
r=mid-1;
}
}
ans+=(R+R+l*t2)*(l+1)/2;
// cout<<R<<" "<<R+l*t2<<" "<<l-1<<"\n";
}
l1+=t1;
}
}
cout<<ans<<"\n";
}
signed main(){
ios::sync_with_stdio(0);
cin.tie(nullptr),cout.tie(nullptr);
int T=1;
// cin>>T;
while(T--){
solve();
}
}
详细
Test #1:
score: 100
Accepted
time: 0ms
memory: 3632kb
input:
ans=0 for a in range(1,3): for b in range(5,1,-2): ans+=b print(ans)
output:
16
result:
ok single line: '16'
Test #2:
score: 0
Accepted
time: 0ms
memory: 3624kb
input:
ans=0 for q in range(100,50,-1): for i in range(q,77,20): ans+=i print(ans)
output:
2092
result:
ok single line: '2092'
Test #3:
score: 0
Accepted
time: 76ms
memory: 3860kb
input:
ans=0 for i in range(1,1000000): for j in range(i,1,-1): ans+=j print(ans)
output:
166666666665500001
result:
ok single line: '166666666665500001'
Test #4:
score: 0
Accepted
time: 8ms
memory: 3860kb
input:
ans=0 for i in range(31,321983,2): for j in range(313,382193): ans+=j print(ans)
output:
11756963404587200
result:
ok single line: '11756963404587200'
Test #5:
score: 0
Accepted
time: 67ms
memory: 3624kb
input:
ans=0 for i in range(1,1000000): for j in range(i,114514,-1): ans+=j print(ans)
output:
160610445975856765
result:
ok single line: '160610445975856765'
Extra Test:
score: 0
Extra Test Passed