Submission #437883

#TimeUsernameProblemLanguageResultExecution timeMemory
437883HaidaraDNA 돌연변이 (IOI21_dna)C++17
Compilation error
0 ms0 KiB
/* * * * * * * * * * * ID: Haidara * * LANG: C++17 * * PROB: * * * * * * * * * * */ #include<bits/stdc++.h> #define fast ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL); #define int long long #define rep(i,x,n) for(int i=x;i<n;i++) #define FOR(i,n) rep(i,0,n) #define per(i,x,n) for(int i=x;i>n;i--) #define ROF(i,x) for(int i=x;i>=0;i--) #define v(i) vector< i > #define p(i,j) pair< i , j > #define pii pair<int,int> #define m(i,j) map< i , j > #define pq(i) priority_queue< i > #define ff first #define all(x) x.begin(),x.end() #define ss second #define pp push_back using namespace std; void SIO(string name="") { if(name!="") { freopen((name+".in").c_str(),"r",stdin); freopen((name+".out").c_str(),"w",stdout); } } const int inf=1LL<<62LL; const int mod=1e9+7; const int maxn=100100; int st[3][2][maxn*4]; string str[2]; int n; int idx; void build(int l=1,int r=n,int inx=1) { if(l==r) { if(str[idx][l]=='T') st[2][idx][inx]=1; if(str[idx][l]=='C') st[2][idx][inx]=1; if(str[idx][l]=='A') st[2][idx][inx]=1; return ; } int mid=l+(r-l)/2; build(l,mid,inx*2); build(mid+1,r,inx*2+1); FOR(i,3) st[i][idx][inx]=st[i][idx][inx*2]+st[i][idx][inx*2+1]; return ; } int f[3],s[3]; void query(int ql,int qr,int l=1,int r=n,int inx=1) { if(ql<=l&&r<=qr) { FOR(i,3) f[i]+=st[i][0][inx],s[i]+=st[i][1][inx]; return ; } if(l>qr||r<ql) return ; int mid=l+(r-l)/2; query(ql,qr,l,mid,inx*2); query(ql,qr,mid+1,r,inx*2+1); return ; } void init(string a, string b) { str[0]=a; str[1]=b; } int get_distance(int x, int y) { x++,y++; FOR(i,3) f[i]=s[i]=0; int ans=y-x; query(x,y); FOR(i,3) if(f[i]!=s[i]) ans=-1; return ans; } int main() { int n, q; assert(scanf("%d %d", &n, &q) == 2); char A[n+1], B[n+1]; assert(scanf("%s", A) == 1); assert(scanf("%s", B) == 1); std::string a = std::string(A); std::string b = std::string(B); std::vector<int> x(q), y(q); for (int i = 0; i < q; i++) { assert(scanf("%d %d", &x[i], &y[i]) == 2); } fclose(stdin); std::vector<int> results(q); init(a, b); for (int i = 0; i < q; i++) { results[i] = get_distance(x[i], y[i]); } for (int i = 0; i < q; i++) { printf("%d\n", results[i]); } fclose(stdout); return 0; }

Compilation message (stderr)

cc1plus: error: '::main' must return 'int'
In file included from /usr/include/c++/10/cassert:44,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:33,
                 from dna.cpp:6:
dna.cpp: In function 'int main()':
dna.cpp:92:15: warning: format '%d' expects argument of type 'int*', but argument 2 has type 'long long int*' [-Wformat=]
   92 |  assert(scanf("%d %d", &n, &q) == 2);
      |               ^~~~~~~  ~~
      |                        |
      |                        long long int*
dna.cpp:92:17: note: format string is defined here
   92 |  assert(scanf("%d %d", &n, &q) == 2);
      |                ~^
      |                 |
      |                 int*
      |                %lld
In file included from /usr/include/c++/10/cassert:44,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:33,
                 from dna.cpp:6:
dna.cpp:92:15: warning: format '%d' expects argument of type 'int*', but argument 3 has type 'long long int*' [-Wformat=]
   92 |  assert(scanf("%d %d", &n, &q) == 2);
      |               ^~~~~~~      ~~
      |                            |
      |                            long long int*
dna.cpp:92:20: note: format string is defined here
   92 |  assert(scanf("%d %d", &n, &q) == 2);
      |                   ~^
      |                    |
      |                    int*
      |                   %lld
In file included from /usr/include/c++/10/cassert:44,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:33,
                 from dna.cpp:6:
dna.cpp:100:16: warning: format '%d' expects argument of type 'int*', but argument 2 has type '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type*' {aka 'long long int*'} [-Wformat=]
  100 |   assert(scanf("%d %d", &x[i], &y[i]) == 2);
      |                ^~~~~~~
dna.cpp:100:18: note: format string is defined here
  100 |   assert(scanf("%d %d", &x[i], &y[i]) == 2);
      |                 ~^
      |                  |
      |                  int*
      |                 %lld
In file included from /usr/include/c++/10/cassert:44,
                 from /usr/include/x86_64-linux-gnu/c++/10/bits/stdc++.h:33,
                 from dna.cpp:6:
dna.cpp:100:16: warning: format '%d' expects argument of type 'int*', but argument 3 has type '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type*' {aka 'long long int*'} [-Wformat=]
  100 |   assert(scanf("%d %d", &x[i], &y[i]) == 2);
      |                ^~~~~~~
dna.cpp:100:21: note: format string is defined here
  100 |   assert(scanf("%d %d", &x[i], &y[i]) == 2);
      |                    ~^
      |                     |
      |                     int*
      |                    %lld
dna.cpp:109:12: warning: format '%d' expects argument of type 'int', but argument 2 has type '__gnu_cxx::__alloc_traits<std::allocator<long long int>, long long int>::value_type' {aka 'long long int'} [-Wformat=]
  109 |   printf("%d\n", results[i]);
      |           ~^
      |            |
      |            int
      |           %lld
dna.cpp: In function 'void SIO(std::string)':
dna.cpp:27:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   27 |         freopen((name+".in").c_str(),"r",stdin);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~
dna.cpp:28:16: warning: ignoring return value of 'FILE* freopen(const char*, const char*, FILE*)' declared with attribute 'warn_unused_result' [-Wunused-result]
   28 |         freopen((name+".out").c_str(),"w",stdout);
      |         ~~~~~~~^~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~~