Submission #76730

#TimeUsernameProblemLanguageResultExecution timeMemory
76730farukkastamonudaLollipop (POI11_liz)C++14
82 / 100
549 ms81652 KiB
#include <bits/stdc++.h> #define li 1000005 using namespace std; int n,m,lol[li*2],p,fk=-1,k; char s[li]; vector<int> v; bool naive(int k){ if(fk<0) return false; if(~lol[fk]&&~lol[fk+k]){ printf("%d %d\n",lol[fk]+1,lol[fk+k]); return true; } int bul=upper_bound(v.begin(),v.end(),k)-v.begin(); if(bul==(int)v.size()){ return false; } int l=v[bul]; if(~lol[l-k]&&lol[l]){ printf("%d %d\n",lol[l-k]+1,lol[l]); return true; } return false; } int main(){ scanf("%d %d",&n,&m); scanf("%s",s); memset(lol,-1,sizeof(lol)); lol[0]=0; for(int i=0;i<n;i++){ if(s[i]=='T'){ p+=2; lol[p]=i+1; } else{ p+=1; lol[p]=i+1; v.push_back(p); if(fk<0) fk=p; } } for(int i=1;i<=m;i++){ scanf("%d",&k); if(~lol[k]){ printf("1 %d\n",lol[k]); } else{ if(!naive(k)) printf("NIE\n"); } } return 0; }

Compilation message (stderr)

liz.cpp: In function 'int main()':
liz.cpp:25:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%d %d",&n,&m);
     ~~~~~^~~~~~~~~~~~~~~
liz.cpp:26:10: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
     scanf("%s",s);
     ~~~~~^~~~~~~~
liz.cpp:42:14: warning: ignoring return value of 'int scanf(const char*, ...)', declared with attribute warn_unused_result [-Wunused-result]
         scanf("%d",&k);
         ~~~~~^~~~~~~~~
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...
#Verdict Execution timeMemoryGrader output
Fetching results...