Submission #94681

# Submission time Handle Problem Language Result Execution time Memory
94681 2019-01-22T13:59:06 Z quoriess Mate (COCI18_mate) C++14
Compilation error
0 ms 0 KB
#include <bits/stdc++.h>
using namespace std;
typedef long long int lli;
typedef pair<lli,lli> pii;
#define dbg(x) cout<<#x<<" has a value of: "<<x<<"\n";
#define usize(x) (int)(x.size())
#define plist(x) for(int i=0;i<usize(x);i++)cout<<"eleman "<<i<<" = "<<x[i]<<"\n";
#define foreach(x) for(auto item:x)
#define fill(s,x) for(int i=0;i<x;i++)cin>>s[i];
#define in(veriler,a) (veriler.find(a)!=veriler.end())
#define btw(x,y,z) x>=y && x<=z
std::ostream& operator<<(std::ostream& os, pair<int,int> p) {
    os << p.first << ", " << p.second;
    return os;
}
const lli MOD=1e9+7;
const int MAXN=2005;
lli rmod(lli x){
	return ((x%MOD)+MOD)%MOD;
}
lli comb[MAXN][MAXN];
void precalc(){
	comb[0][0]=1;
	comb[1][0]=comb[1][1]=1;
	for (int i = 2; i <MAXN ; i++)
	{
		comb[i][0]=1;
		for (int j = 1; j <= i; j++)
		{
			comb[i][j]=rmod(comb[i-1][j]+comb[i-1][j-1]);
		}
	}
}
int main(){
	precalc();
	string s;
	cin>>s;
	int n=s.size();
	vector<vector<int> > pre(n+1,vector<int>(26));
	for (int i = 1; i <= n; i++)
	{
		for(int j=0;j<26;j++){
			pre[i][j]=pre[i-1][j];
		}
		pre[i][s[i-1]-97]=pre[i-1][s[i-1]-97]+1;
	}
	vector<vector<vector<int> > > calc(n+1,vector<vector<lli> >(n+1,vector<lli>(26,0)));
	for (int i = 1; i <= n; i++)
	{
		for (int j = 0; j <= n; j++)
		{
			for (int k = 0; k < 26; k++)
			{
				calc[i][j][k]=rmod((pre[n][k]-pre[i][k])*comb[i-1][j]);
			}
		}
	}
	vector<vector<vector<int> > > calcpre(26,vector<vector<lli> >(n+1,vector<lli>(26,0)));
	for (int i = 1; i <= n; i++)
	{
		for (int j = 0; j <= n; j++)
		{
			for (int k = 0; k < 26; k++)
			{
				calcpre[s[i-1]-97][j][k]=rmod(calcpre[s[i-1]-97][j][k]+calc[i][j][k]);
			}
		}
	}
	int q;
	cin>>q;
	for (int i = 0; i < q; i++)
	{
		int x;
		cin>>x;
		char c1,c2;
		cin>>c1>>c2;
		cout<<calcpre[c1-97][x-2][c2-97]<<"\n";
	}
	return 0;
}

Compilation message

mate.cpp: In function 'int main()':
mate.cpp:47:84: error: no matching function for call to 'std::vector<std::vector<std::vector<int> > >::vector(int, std::vector<std::vector<long long int> >)'
  vector<vector<vector<int> > > calc(n+1,vector<vector<lli> >(n+1,vector<lli>(26,0)));
                                                                                    ^
In file included from /usr/include/c++/7/vector:64:0,
                 from /usr/include/c++/7/queue:61,
                 from /usr/include/x86_64-linux-gnu/c++/7/bits/stdc++.h:86,
                 from mate.cpp:1:
/usr/include/c++/7/bits/stl_vector.h:411:2: note: candidate: template<class _InputIterator, class> std::vector<_Tp, _Alloc>::vector(_InputIterator, _InputIterator, const allocator_type&)
  vector(_InputIterator __first, _InputIterator __last,
  ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:411:2: note:   template argument deduction/substitution failed:
mate.cpp:47:84: note:   deduced conflicting types for parameter '_InputIterator' ('int' and 'std::vector<std::vector<long long int> >')
  vector<vector<vector<int> > > calc(n+1,vector<vector<lli> >(n+1,vector<lli>(26,0)));
                                                                                    ^
In file included from /usr/include/c++/7/vector:64:0,
                 from /usr/include/c++/7/queue:61,
                 from /usr/include/x86_64-linux-gnu/c++/7/bits/stdc++.h:86,
                 from mate.cpp:1:
/usr/include/c++/7/bits/stl_vector.h:383:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::initializer_list<_Tp>, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(initializer_list<value_type> __l,
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:383:7: note:   no known conversion for argument 1 from 'int' to 'std::initializer_list<std::vector<std::vector<int> > >'
/usr/include/c++/7/bits/stl_vector.h:358:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>&&, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(vector&& __rv, const allocator_type& __m)
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:358:7: note:   no known conversion for argument 1 from 'int' to 'std::vector<std::vector<std::vector<int> > >&&'
/usr/include/c++/7/bits/stl_vector.h:348:7: note: candidate: std::vector<_Tp, _Alloc>::vector(const std::vector<_Tp, _Alloc>&, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(const vector& __x, const allocator_type& __a)
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:348:7: note:   no known conversion for argument 1 from 'int' to 'const std::vector<std::vector<std::vector<int> > >&'
/usr/include/c++/7/bits/stl_vector.h:344:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>&&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >]
       vector(vector&& __x) noexcept
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:344:7: note:   candidate expects 1 argument, 2 provided
/usr/include/c++/7/bits/stl_vector.h:326:7: note: candidate: std::vector<_Tp, _Alloc>::vector(const std::vector<_Tp, _Alloc>&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >]
       vector(const vector& __x)
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:326:7: note:   candidate expects 1 argument, 2 provided
/usr/include/c++/7/bits/stl_vector.h:295:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>::size_type, const value_type&, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::size_type = long unsigned int; std::vector<_Tp, _Alloc>::value_type = std::vector<std::vector<int> >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(size_type __n, const value_type& __value,
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:295:7: note:   no known conversion for argument 2 from 'std::vector<std::vector<long long int> >' to 'const value_type& {aka const std::vector<std::vector<int> >&}'
/usr/include/c++/7/bits/stl_vector.h:283:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>::size_type, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::size_type = long unsigned int; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(size_type __n, const allocator_type& __a = allocator_type())
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:283:7: note:   no known conversion for argument 2 from 'std::vector<std::vector<long long int> >' to 'const allocator_type& {aka const std::allocator<std::vector<std::vector<int> > >&}'
/usr/include/c++/7/bits/stl_vector.h:270:7: note: candidate: std::vector<_Tp, _Alloc>::vector(const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(const allocator_type& __a) _GLIBCXX_NOEXCEPT
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:270:7: note:   candidate expects 1 argument, 2 provided
/usr/include/c++/7/bits/stl_vector.h:259:7: note: candidate: std::vector<_Tp, _Alloc>::vector() [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >]
       vector()
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:259:7: note:   candidate expects 0 arguments, 2 provided
mate.cpp:58:86: error: no matching function for call to 'std::vector<std::vector<std::vector<int> > >::vector(int, std::vector<std::vector<long long int> >)'
  vector<vector<vector<int> > > calcpre(26,vector<vector<lli> >(n+1,vector<lli>(26,0)));
                                                                                      ^
In file included from /usr/include/c++/7/vector:64:0,
                 from /usr/include/c++/7/queue:61,
                 from /usr/include/x86_64-linux-gnu/c++/7/bits/stdc++.h:86,
                 from mate.cpp:1:
/usr/include/c++/7/bits/stl_vector.h:411:2: note: candidate: template<class _InputIterator, class> std::vector<_Tp, _Alloc>::vector(_InputIterator, _InputIterator, const allocator_type&)
  vector(_InputIterator __first, _InputIterator __last,
  ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:411:2: note:   template argument deduction/substitution failed:
mate.cpp:58:86: note:   deduced conflicting types for parameter '_InputIterator' ('int' and 'std::vector<std::vector<long long int> >')
  vector<vector<vector<int> > > calcpre(26,vector<vector<lli> >(n+1,vector<lli>(26,0)));
                                                                                      ^
In file included from /usr/include/c++/7/vector:64:0,
                 from /usr/include/c++/7/queue:61,
                 from /usr/include/x86_64-linux-gnu/c++/7/bits/stdc++.h:86,
                 from mate.cpp:1:
/usr/include/c++/7/bits/stl_vector.h:383:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::initializer_list<_Tp>, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(initializer_list<value_type> __l,
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:383:7: note:   no known conversion for argument 1 from 'int' to 'std::initializer_list<std::vector<std::vector<int> > >'
/usr/include/c++/7/bits/stl_vector.h:358:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>&&, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(vector&& __rv, const allocator_type& __m)
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:358:7: note:   no known conversion for argument 1 from 'int' to 'std::vector<std::vector<std::vector<int> > >&&'
/usr/include/c++/7/bits/stl_vector.h:348:7: note: candidate: std::vector<_Tp, _Alloc>::vector(const std::vector<_Tp, _Alloc>&, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(const vector& __x, const allocator_type& __a)
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:348:7: note:   no known conversion for argument 1 from 'int' to 'const std::vector<std::vector<std::vector<int> > >&'
/usr/include/c++/7/bits/stl_vector.h:344:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>&&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >]
       vector(vector&& __x) noexcept
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:344:7: note:   candidate expects 1 argument, 2 provided
/usr/include/c++/7/bits/stl_vector.h:326:7: note: candidate: std::vector<_Tp, _Alloc>::vector(const std::vector<_Tp, _Alloc>&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >]
       vector(const vector& __x)
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:326:7: note:   candidate expects 1 argument, 2 provided
/usr/include/c++/7/bits/stl_vector.h:295:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>::size_type, const value_type&, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::size_type = long unsigned int; std::vector<_Tp, _Alloc>::value_type = std::vector<std::vector<int> >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(size_type __n, const value_type& __value,
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:295:7: note:   no known conversion for argument 2 from 'std::vector<std::vector<long long int> >' to 'const value_type& {aka const std::vector<std::vector<int> >&}'
/usr/include/c++/7/bits/stl_vector.h:283:7: note: candidate: std::vector<_Tp, _Alloc>::vector(std::vector<_Tp, _Alloc>::size_type, const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::size_type = long unsigned int; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(size_type __n, const allocator_type& __a = allocator_type())
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:283:7: note:   no known conversion for argument 2 from 'std::vector<std::vector<long long int> >' to 'const allocator_type& {aka const std::allocator<std::vector<std::vector<int> > >&}'
/usr/include/c++/7/bits/stl_vector.h:270:7: note: candidate: std::vector<_Tp, _Alloc>::vector(const allocator_type&) [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >; std::vector<_Tp, _Alloc>::allocator_type = std::allocator<std::vector<std::vector<int> > >]
       vector(const allocator_type& __a) _GLIBCXX_NOEXCEPT
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:270:7: note:   candidate expects 1 argument, 2 provided
/usr/include/c++/7/bits/stl_vector.h:259:7: note: candidate: std::vector<_Tp, _Alloc>::vector() [with _Tp = std::vector<std::vector<int> >; _Alloc = std::allocator<std::vector<std::vector<int> > >]
       vector()
       ^~~~~~
/usr/include/c++/7/bits/stl_vector.h:259:7: note:   candidate expects 0 arguments, 2 provided