#2610
Discuri
Se dau N
numere reale considerate ca fiind razele a N
discuri. Considerăm că așezăm un disc în sistemul xOy
dacă îl plasăm la o coordonată x
pozitivă suficient de mare, tangent cu axa Ox
și deasupra ei, apoi îl împingem spre Oy
până când devine tangent cu Oy
sau cu primul disc așezat anterior întâlnit. În figura rezultată după așezarea tuturor discurilor în ordinea dată unele dintre ele pot fi considerate dispensabile, pentru că prin eliminarea lor nu se modifică lățimea totală a figurii, adică nici un disc nu se mai poate deplasa spre stânga. Identificați toate discurile dispensabile din figură.
Problema | Discuri | Operații I/O |
discuri.in /discuri.out
|
---|---|---|---|
Limita timp | 1 secunde | Limita memorie |
Total: 64 MB
/
Stivă 8 MB
|
Id soluție | #14962222 | Utilizator | |
Fișier | discuri.cpp | Dimensiune | 1.22 KB |
Data încărcării | 26 Martie 2019, 14:14 | Scor / rezultat | Eroare de compilare |
discuri.cpp: In function 'void xFinder(int)': discuri.cpp:20:5: error: 'r' was not declared in this scope r=v[i].r; ^ discuri.cpp:20:9: error: 'i' was not declared in this scope r=v[i].r; ^ discuri.cpp:24:16: error: 'mxX' was not declared in this scope if(tmp>mxX) ^ discuri.cpp:27:13: error: 'mxI' was not declared in this scope mxI=i; ^ discuri.cpp:30:7: error: 'mxI' was not declared in this scope v[mxI].victims.push(pos); ^ discuri.cpp:31:14: error: 'mxX' was not declared in this scope v[pos].x=mxX; ^ discuri.cpp: In function 'bool canBeRemoved(int)': discuri.cpp:38:34: error: no match for 'operator!=' (operand types are 'std::vector<int>' and 'std::vector<int>::iterator {aka __gnu_cxx::__normal_iterator<int*, std::vector<int> >}') for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ discuri.cpp:38:34: note: candidates are: In file included from /usr/include/c++/4.8/iosfwd:40:0, from /usr/include/c++/4.8/ios:38, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/postypes.h:221:5: note: template<class _StateT> bool std::operator!=(const std::fpos<_StateT>&, const std::fpos<_StateT>&) operator!=(const fpos<_StateT>& __lhs, const fpos<_StateT>& __rhs) ^ /usr/include/c++/4.8/bits/postypes.h:221:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::fpos<_StateT>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:64:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_pair.h:227:5: note: template<class _T1, class _T2> constexpr bool std::operator!=(const std::pair<_T1, _T2>&, const std::pair<_T1, _T2>&) operator!=(const pair<_T1, _T2>& __x, const pair<_T1, _T2>& __y) ^ /usr/include/c++/4.8/bits/stl_pair.h:227:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::pair<_T1, _T2>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:67:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_iterator.h:303:5: note: template<class _Iterator> bool std::operator!=(const std::reverse_iterator<_Iterator>&, const std::reverse_iterator<_Iterator>&) operator!=(const reverse_iterator<_Iterator>& __x, ^ /usr/include/c++/4.8/bits/stl_iterator.h:303:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::reverse_iterator<_Iterator>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:67:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_iterator.h:353:5: note: template<class _IteratorL, class _IteratorR> bool std::operator!=(const std::reverse_iterator<_Iterator>&, const std::reverse_iterator<_IteratorR>&) operator!=(const reverse_iterator<_IteratorL>& __x, ^ /usr/include/c++/4.8/bits/stl_iterator.h:353:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::reverse_iterator<_Iterator>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:67:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_iterator.h:1043:5: note: template<class _IteratorL, class _IteratorR> bool std::operator!=(const std::move_iterator<_Iterator>&, const std::move_iterator<_IteratorR>&) operator!=(const move_iterator<_IteratorL>& __x, ^ /usr/include/c++/4.8/bits/stl_iterator.h:1043:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::move_iterator<_Iterator>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:67:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_iterator.h:1049:5: note: template<class _Iterator> bool std::operator!=(const std::move_iterator<_Iterator>&, const std::move_iterator<_Iterator>&) operator!=(const move_iterator<_Iterator>& __x, ^ /usr/include/c++/4.8/bits/stl_iterator.h:1049:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::move_iterator<_Iterator>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/string:41:0, from /usr/include/c++/4.8/bits/locale_classes.h:40, from /usr/include/c++/4.8/bits/ios_base.h:41, from /usr/include/c++/4.8/ios:42, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/allocator.h:138:5: note: template<class _T1, class _T2> bool std::operator!=(const std::allocator<_CharT>&, const std::allocator<_T2>&) operator!=(const allocator<_T1>&, const allocator<_T2>&) ^ /usr/include/c++/4.8/bits/allocator.h:138:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::allocator<_CharT>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/string:41:0, from /usr/include/c++/4.8/bits/locale_classes.h:40, from /usr/include/c++/4.8/bits/ios_base.h:41, from /usr/include/c++/4.8/ios:42, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/allocator.h:143:5: note: template<class _Tp> bool std::operator!=(const std::allocator<_CharT>&, const std::allocator<_CharT>&) operator!=(const allocator<_Tp>&, const allocator<_Tp>&) ^ /usr/include/c++/4.8/bits/allocator.h:143:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::allocator<_CharT>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/string:52:0, from /usr/include/c++/4.8/bits/locale_classes.h:40, from /usr/include/c++/4.8/bits/ios_base.h:41, from /usr/include/c++/4.8/ios:42, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/basic_string.h:2532:5: note: template<class _CharT, class _Traits, class _Alloc> bool std::operator!=(const std::basic_string<_CharT, _Traits, _Alloc>&, const std::basic_string<_CharT, _Traits, _Alloc>&) operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, ^ /usr/include/c++/4.8/bits/basic_string.h:2532:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::basic_string<_CharT, _Traits, _Alloc>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/string:52:0, from /usr/include/c++/4.8/bits/locale_classes.h:40, from /usr/include/c++/4.8/bits/ios_base.h:41, from /usr/include/c++/4.8/ios:42, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/basic_string.h:2544:5: note: template<class _CharT, class _Traits, class _Alloc> bool std::operator!=(const _CharT*, const std::basic_string<_CharT, _Traits, _Alloc>&) operator!=(const _CharT* __lhs, ^ /usr/include/c++/4.8/bits/basic_string.h:2544:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: mismatched types 'const _CharT*' and 'std::vector<int>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/string:52:0, from /usr/include/c++/4.8/bits/locale_classes.h:40, from /usr/include/c++/4.8/bits/ios_base.h:41, from /usr/include/c++/4.8/ios:42, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/basic_string.h:2556:5: note: template<class _CharT, class _Traits, class _Alloc> bool std::operator!=(const std::basic_string<_CharT, _Traits, _Alloc>&, const _CharT*) operator!=(const basic_string<_CharT, _Traits, _Alloc>& __lhs, ^ /usr/include/c++/4.8/bits/basic_string.h:2556:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::basic_string<_CharT, _Traits, _Alloc>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/locale_facets.h:48:0, from /usr/include/c++/4.8/bits/basic_ios.h:37, from /usr/include/c++/4.8/ios:44, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/streambuf_iterator.h:210:5: note: template<class _CharT, class _Traits> bool std::operator!=(const std::istreambuf_iterator<_CharT, _Traits>&, const std::istreambuf_iterator<_CharT, _Traits>&) operator!=(const istreambuf_iterator<_CharT, _Traits>& __a, ^ /usr/include/c++/4.8/bits/streambuf_iterator.h:210:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const std::istreambuf_iterator<_CharT, _Traits>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/vector:64:0, from discuri.cpp:2: /usr/include/c++/4.8/bits/stl_vector.h:1428:5: note: template<class _Tp, class _Alloc> bool std::operator!=(const std::vector<_Tp, _Alloc>&, const std::vector<_Tp, _Alloc>&) operator!=(const vector<_Tp, _Alloc>& __x, const vector<_Tp, _Alloc>& __y) ^ /usr/include/c++/4.8/bits/stl_vector.h:1428:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>::iterator {aka __gnu_cxx::__normal_iterator<int*, std::vector<int> >}' is not derived from 'const std::vector<_Tp, _Alloc>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/i386-linux-gnu/c++/4.8/bits/c++allocator.h:33:0, from /usr/include/c++/4.8/bits/allocator.h:46, from /usr/include/c++/4.8/string:41, from /usr/include/c++/4.8/bits/locale_classes.h:40, from /usr/include/c++/4.8/bits/ios_base.h:41, from /usr/include/c++/4.8/ios:42, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/ext/new_allocator.h:144:5: note: template<class _Tp> bool __gnu_cxx::operator!=(const __gnu_cxx::new_allocator<_Tp>&, const __gnu_cxx::new_allocator<_Tp>&) operator!=(const new_allocator<_Tp>&, const new_allocator<_Tp>&) ^ /usr/include/c++/4.8/ext/new_allocator.h:144:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const __gnu_cxx::new_allocator<_Tp>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:67:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_iterator.h:823:5: note: template<class _Iterator, class _Container> bool __gnu_cxx::operator!=(const __gnu_cxx::__normal_iterator<_Iterator, _Container>&, const __gnu_cxx::__normal_iterator<_Iterator, _Container>&) operator!=(const __normal_iterator<_Iterator, _Container>& __lhs, ^ /usr/include/c++/4.8/bits/stl_iterator.h:823:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const __gnu_cxx::__normal_iterator<_Iterator, _Container>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ In file included from /usr/include/c++/4.8/bits/stl_algobase.h:67:0, from /usr/include/c++/4.8/bits/char_traits.h:39, from /usr/include/c++/4.8/ios:40, from /usr/include/c++/4.8/ostream:38, from /usr/include/c++/4.8/iostream:39, from discuri.cpp:1: /usr/include/c++/4.8/bits/stl_iterator.h:817:5: note: template<class _IteratorL, class _IteratorR, class _Container> bool __gnu_cxx::operator!=(const __gnu_cxx::__normal_iterator<_IteratorL, _Container>&, const __gnu_cxx::__normal_iterator<_IteratorR, _Container>&) operator!=(const __normal_iterator<_IteratorL, _Container>& __lhs, ^ /usr/include/c++/4.8/bits/stl_iterator.h:817:5: note: template argument deduction/substitution failed: discuri.cpp:38:55: note: 'std::vector<int>' is not derived from 'const __gnu_cxx::__normal_iterator<_IteratorL, _Container>' for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ discuri.cpp:38:57: error: no match for 'operator++' (operand type is 'std::vector<int>') for(auto it=v[pos].victims;it!=v[pos].victims.end();++it) ^ discuri.cpp:40:29: error: 'i' was not declared in this scope if(v[v[pos].victims[i]].removed==false) ^ discuri.cpp: In function 'int main()': discuri.cpp:48:10: error: 'n' was not declared in this scope cin>>n; ^ discuri.cpp:59:13: error: 'sol' was not declared in this scope sol[++nrSol]=i; ^ discuri.cpp:59:19: error: 'nrSol' was not declared in this scope sol[++nrSol]=i; ^ discuri.cpp:62:11: error: 'nrSol' was not declared in this scope cout<<nrSol<<'\n'; ^ discuri.cpp:63:10: error: 'sol' was not declared in this scope sort(sol+1,sol+1+nrSol); ^ discuri.cpp:63:27: error: 'sort' was not declared in this scope sort(sol+1,sol+1+nrSol); ^
www.pbinfo.ro permite evaluarea a două tipuri de probleme:
Problema Discuri face parte din prima categorie. Soluția propusă de tine va fi evaluată astfel:
Suma punctajelor acordate pe testele utilizate pentru verificare este 100. Astfel, soluția ta poate obține cel mult 100 de puncte, caz în care se poate considera corectă.