Показать все ветки Спрятать все ветки Показать все сообщения Спрятать все сообщения | YES or NO? | Dmi3Molodov | 1021. Таинство суммы | 29 ноя 2024 01:29 | 1 | test: 1 10000 0 How do I answer "YES" or "NO"? ooopsss! Zero not allowed! Sorry. Edited by author 29.11.2024 01:34 | Can anyone tell me whats wrong with this code | Programmer | 1021. Таинство суммы | 26 июл 2022 16:00 | 1 | #include <bits/stdc++.h> using namespace std; int main(){ int n1,n2; int a[n1],b[n2]; cin>>n1; for(int k=0;k<n1;k++) cin>>a[k]; cin>>n2; for(int k=0;k<n2;k++) cin>>b[k]; sort(a,a+n1); sort(b,b+n2); int i=0,j=n2-1; bool ans=false; while(i<n1&&j>=0){ if(a[i]+b[j]==10000){ ans=true; break; } else if(a[i]+b[j]>10000){ j--; } else{ i++; } } if(ans) cout<<"YES"<<endl; else cout<<"NO"<<endl; return 0; } | Hint, Solution & Code(C++) | Asif Anwar Sajid | 1021. Таинство суммы | 1 июн 2021 13:46 | 2 | Hint: Binary search!! Solution: This is a pretty easy binary search problem. All we need is to check for every number of the second list(as first list is sorted in ascending order) let's denote as x, if we can find y = 10000-x in the first list. If we find y for any x(from the 2nd list) then we will print "YES". Because we already got a pair x, y for which x + y = 10000. So, the complexity is NlogN(as we are doing binary search for every element of a list in the worst case). [Code was deleted] Edited by moderator 06.06.2021 03:06 Binary search is not needed here. It is enough to traverse the array with two pointers. | test 5 | Firchalka | 1021. Таинство суммы | 16 июн 2020 19:27 | 1 | test 5 Firchalka 16 июн 2020 19:27 | For those at whom the wrong answer to the 12th test. | vin | 1021. Таинство суммы | 24 янв 2020 20:01 | 2 | Try the following 2 tests: 2 0 10000 2 20000 10000 and 2 0 10000 2 0 -10000 What answer is issued by your program? Edited by author 14.02.2013 20:37 YES, YES and look like its right? | So easy / phyton 3 solution | SMMaster | 1021. Таинство суммы | 30 дек 2019 14:32 | 1 | o = 0 k = int(input()) a = [0] * (65536*2) for i in range(k): a[int(input()) + 32768] = 1 h = int(input()) for i in range(h): if a[10000 - int(input()) + 32768] != 0: o += 1 if o >= 1: print('YES') else: print('NO') | WHAT? TIME LIMIT EXCEEDED. PLEASE HELP! | mNT | 1021. Таинство суммы | 23 июл 2018 12:30 | 1 | type a = array[1..50000] of integer; b = array[1..50000] of integer;
Var c,d,i,k,g: integer; Var n: a; Var p: b;
begin d:= 0; read(c); for i:= 1 to c do read(n[i]); read(k); for i:= 1 to k do read(p[i]);
for i:=1 to c do for g:=1 to k do begin if (n[i] + p[g] = 10000) then begin writeln('YES'); exit; end else if (i = c) and (g = k) and (n[i] + p[g] <> 10000) then begin writeln('NO'); exit; end; end; end. | accepted | Mikhail | 1021. Таинство суммы | 22 май 2018 00:58 | 1 | //#pragma GCC optimize("Ofast,no-stack-protector") //#pragma GCC target("avx") #include <bits/stdc++.h> #include <ext/pb_ds/assoc_container.hpp> #include <ext/pb_ds/tree_policy.hpp>
using namespace __gnu_pbds; using namespace std;
#define re return #define pb push_back #define eb emplace_back #define all(x) (x).begin(), (x).end() #define fi first #define se second #define sqrt(x) sqrt(abs(x)) #define mp make_pair #define pi (3.14159265358979323846264338327950288419716939937510) #define fo(i, n) for(int i = 0; i < n; ++i) #define ro(i, n) for(int i = n - 1; i >= 0; --i) #define unique(v) v.resize(unique(all(v)) - v.begin())
template <class T> T abs (T x) { re x > 0 ? x : -x; } template <class T> T sqr (T x) { re x * x; } template <class T> T gcd (T a, T b) { re a ? gcd (b % a, a) : b; } template <class T> int sgn (T x) { re x > 0 ? 1 : (x < 0 ? -1 : 0); }
typedef vector<int> vi; typedef vector<vi> vvi; typedef pair<int, int> ii; typedef vector<ii> vii; typedef vector<string> vs; typedef double D; typedef long double ld; typedef long long ll; typedef pair<ll, ll> pll; typedef vector<ll> vll; typedef unsigned long long ull; typedef tree <pair<int, char>, null_type, less<pair<int, char>>, rb_tree_tag, tree_order_statistics_node_update> _tree;
const int maxn = (int) 1e5 + 10; int a[maxn], b[maxn]; int main() { int n, m; cin >> n; fo(i, n) cin >> a[i]; int x, pos, ans; cin >> m; fo(i, m) { cin >> x; x = 10000 - x; ans = (int)1e9; pos = lower_bound(a, a + n, x) - a; for (int i = max(0, pos - 1), end = min(n - 1, pos + 1); i <= end; ++i) ans = min(ans, abs(x - a[i])); if (!ans) { cout << "YES\n"; re 0; } } cout << "NO\n"; re 0; } | What's wrong? help please! | Rezik | 1021. Таинство суммы | 25 сен 2016 15:57 | 1 | Edited by author 25.09.2016 18:07 | Please help me! I do not know how to charge the time. | hit | 1021. Таинство суммы | 27 апр 2016 14:58 | 3 | #include<stdio.h> #include<stdlib.h> int main() { int m,n,a[50000],b[50000],i,j,p,c; scanf("%d",&n); for(i=0;i<n;i++) { scanf("%d",&a[i]); } scanf("%d",&m); for(i=0;i<m;i++) { scanf("%d",&b[i]); } for(j=0;j<n;j++) { for(p=0;p<m;p++) { c=a[j]+b[p]; if(c==10000) { printf("YES"); exit(0); } } } printf("NO"); return 0; } in my mind, two loops is not required. Try to use binary search in sorted array. steps: 1.Take from first array the number; 2.1000-[this number] 3.find 1000-[this number] in second array(use binary search) This way, you have only one loop. Edited by author 20.11.2015 23:45 Edited by author 20.11.2015 23:45 | Test № 10 | Pavel | 1021. Таинство суммы | 7 окт 2015 21:08 | 1 | What's wrong? Please, answer me. #include <iostream> #include <vector> using namespace std; int main() { bool z; vector <int> so(0), st(0); unsigned int a; cin >> a; while (so.size() < a) { int soe; cin >> soe; so.push_back(soe); } unsigned int b; cin >> b; while (st.size() < b) { int ste; cin >> ste; st.push_back(ste); } for (unsigned int i = 0; i < so.size(); i++) for (unsigned int j = 0; j < st.size(); j++) { if (so[i] + st[j] == 10000) { z = true; } } if (z == true) { cout << "YES" << endl; } else { cout << "NO" << endl; } } Edited by author 24.10.2015 04:23 | Test #3 | Elinchik | 1021. Таинство суммы | 22 июл 2015 23:57 | 6 | Что такое тест № 3? мой алгоритм не прошел этот тест!!! Вообще где найти разъяснения к номерам тестов?? какие-такие разъяснения? раз не прошел 3 тест значит где-то у тебя косяк. Никакой не косяк. Реально тест №3 неправильный. Вот корректное решение: считываем в два массива А и В. Потом цикл по элементам А, и для каждого А(и) пытаемся найти такое В(ж), чтобы А(и)+В(ж)==10000. И получаем ВА. Бред. (поиск бинарный так как отсортированы массивы). #include <iostream> using namespace std; int cmp(const void*A,const void *B){ long t=*(long*)A-*(long*)B; if (t>0) return 1; if (t==0) return 0; if (t<0) return -1; } int main(void){ long N,M,i,j; long *A,*B; long * C; cin>>N; A=new long[N]; for(i=0;i<N;i++) cin>>A[i]; cin>>M; B=new long[M]; for(i=0;i<M;i++) cin>>B[i]; bool t=false; for(i=0;i<N;i++) { j=10000-A[i]; C=(long*)bsearch(&j,B,M,sizeof(long),cmp); if(C!=NULL) if(A[i]+*C==10000){t=true; break;} } if(t)cout<<"YES"; else cout<<"NO"; cout<<endl; system("pause"); return 0; } Очевидно условия некорректны. В условии сказано,что массивы упорядочены. Но достаточно дописать в мое решение qsort(A,N,sizeof(long),cmp); qsort(B,M,sizeof(long),cmp); И вуаля все просто, и получаем АС. Авторы проверяйте условия, или хотя бы читайте форум иногда. Тут нередко попадаются задачи с корявыми тестами, которых не должно быть по условию. Edited by author 03.12.2010 03:00 Процедура bsearch предполагает, что массив должен быть отсортирован в неубывающем порядке, мне не совсем понятен твой компоратор, фактически он ничего не меняет, так процедура bsearch и сравнивает по умолчанию. То есть когда ты отсортировал массив по своему компоратору, ты, фактически, инверитровал его и привел к такому виду, что процедура bsearch будет работать правильно. Попробуй на своей первоначальной программе: 9 3 5 15 20 100 900 5000 9983 15000 9 7000 549 58 17 8 4 0 -10 -30 Правильный ответ: ΥΕS (9983+17) И да:"Если вы не можете решить задачу, значит вы не можете её решить". Re: Test #3 BrainFuck [UFU SESC bash.org/I'ja] 25 апр 2013 18:39 попробовал на своей программе #include <iostream> using namespace std; int main() { int n; cin >> n; int *a = new int[n*2]; for (int i = 0; i < n*2; i++) cin >> a[i]; for (int i = 0; i <n; i++) for (int j = n; j < n*2; j++) if (a[i]+a[j] == 10000) { cout << "YES" << endl; delete [] a; exit (0); } cout << "NO" << endl; delete [] a; return 0; } Выдало YES, к тому же такой алгоритм хоть и можно назвать затратным, но он рабочий. | No subject | zakran | 1021. Таинство суммы | 18 дек 2014 17:42 | 1 | | Help. Runtime error (access violation) | Daniel | 1021. Таинство суммы | 23 сен 2014 15:45 | 2 | Where is my wrong? Why runtime error (access violation)? This is my code- program _1021; var n,i,k,l,m:integer; a,b:array[1..10000] of integer; begin read(n); for i:=1 to n do read(a[i]); read(m); for k:=1 to m do read(b[k]); for i:=1 to n do for k:=1 to m do if a[i]+b[k]=10000 then l:=l+1; if l>=1 then writeln('YES') else writeln('NO'); end. ... a,b:array [1..10000] of integer;... 10000 isn't enough because 1<=n<=50000 | Accepted in Java 1.7 | Axmadjon | 1021. Таинство суммы | 7 май 2014 10:49 | 1 | [delete] Edited by author 07.05.2014 10:53 Edited by author 07.05.2014 10:53 | O(NlogN) C++ soluton | Maxim | 1021. Таинство суммы | 13 фев 2014 03:02 | 1 | /* * File: main.cpp * Author: Maxim Cherchuk <maxim.cherchuk@gmail.com> * * Created on 12 Февраль 2014 г., 23:36 */ #include <iostream> #include <algorithm> using namespace std; /* * */ const int MAXN = 50000, MAX = 10000; int a[MAXN], b[MAXN]; int n, k, m; int main(int argc, char** argv) { ios_base::sync_with_stdio(0); cin >> n; for(int i = 0; i < n; ++i) { cin >> a[i]; } cin >> k; for(int i = 0; i < k; ++i) { cin >> b[i]; } sort(a, a+n); sort(b, b+k); for(int i = 0; i < n; ++i) { const int cur = a[i]; int l = 0; int r = k; while(r-l > 1) { // binary search m = (l+r)>>1; if(cur+b[m] > MAX) r = m; else l = m; } if(cur + b[l] == MAX) { cout << "YES"; return 0; } } cout << "NO"; } | fail | Charm | 1021. Таинство суммы | 15 ноя 2013 12:04 | 6 | fail Charm 5 фев 2011 21:26 В чём ошибка не пойму.? не проходит 1 тест var i,j,k,m,s,n:integer; a,b:array[1..100000] of integer; begin read(n); k:=0; for i:=1 to n do read(a[i]); read(m); for i:=1 to m do read(b[i]); for i:=1 to n do begin for j:=1 to m do begin if a[i]+b[j]=10000 then k:=1; end; end; if k=1 then write('yes'); if k=0 then write('no'); end. Edited by author 05.02.2011 21:26 Edited by author 05.02.2011 21:30 Re: fail Andrew Suhani 24 мар 2011 01:21 Try to use capital letters for the answer: YES and NO Re: fail ilya_romanenko 3 июн 2011 22:40 Исправь "yes" и "no" на "YES" and "NO". Однако после этого будет ТЛЕ на 4 тесте. Используй быструю сортировку и бинарный поиск. Удачи! Sorting not needed because input given in sorted order. Actually you even not need to binary-search, just line scan of both arrays. Think what way summ changed if you pick next item in array. IMHO sortirovka zdes ninado | WA test 14! Help please | Den | 1021. Таинство суммы | 30 окт 2013 12:37 | 2 | #include <stdio.h> int binsup(int key,int *mas,int n); int binsdown(int key,int *mas,int n); int main() { int mas[50100],mas1[50100],i,n,n1,f; scanf("%d",&n); for (i=0; i<n; i++) scanf("%d",&mas[i]); scanf("%d",&n1); for (i=0; i<n1; i++) scanf("%d",&mas1[i]); f=0; if (n>n1) for (i=0; i<n1 && f==0; i++) f=binsup(10000-mas1[i],mas,n); else for (i=0; i<n && f==0; i++) f=binsdown(10000-mas[i],mas1,n1); if (f==0) printf("NO"); else printf("YES"); return 0; } int binsup(int key,int *mas,int n) { int lg,pg,m; lg=0; pg=n; while (lg<=pg) { m=(lg+pg)/2; if (key>mas[m]) lg=m+1; else if (key<mas[m]) pg=m-1; else return 1; } return 0; } int binsdown(int key,int *mas,int n) { int lg,pg,m; lg=0; pg=n; while (lg<=pg) { m=(lg+pg)/2; if (key<mas[m]) lg=m+1; else if (key>mas[m]) pg=m-1; else return 1; } return 0; } //------------------------- what i do wrong? Did u find test #14? Give me this test pls... | Time limit on Test 2 Help. (C++) | Ivailo | 1021. Таинство суммы | 16 авг 2013 12:36 | 3 | Where do I have a problem? I used binary search and got time limit on test 2. But when I use N*N1 speed I pass test 2 and get time limit on test 10. Can you please check my code. I believe it is correct. #include <iostream> using namespace std; bool binary_search (long* b , long a , long from ,long to) { while (from != to) { long mid = (from + to )/2; if (b[mid] + a == 10000) return true; if (b[mid] + a > 10000) { from = mid; } if (b[mid] + a < 10000) { to = mid; } } return false; } int main () { long n , n1; long* a , *b; cin >> n; a = new long[n]; for (int i =0 ; i < n ; i++) { cin >> a[i]; } cin >> n1; b = new long[n1]; for (int i =0 ; i < n1 ; i++ ) { cin >> b[i]; } bool tr = false; for (int i = 0 ; i < n ; i++) { tr = binary_search (b , a[i] , 0 , n1); if (tr) break; } if(tr) cout << "YES"; else cout << "NO"; } "Where do I have a problem?" You've got TLE. That is a problem Ok my bad. Why do I get TLE when I use binary, but don't get TLE when I use n1*n? Isn't binary faster? | Pomogite TLE na 10 teste ; Help TLE on 10 th test | Hamdam_TUIT | 1021. Таинство суммы | 28 июн 2013 10:37 | 1 | #include<iostream> using namespace std; short a[50001],b[50001]; int N,M,index_1_0,index_1_10,index_2_0,index_2_10; bool f_0,f_10,t_0,t_10; const int T=10000; int main() { cin>>N; for(int i=0;i<N;i++) { cin>>a[i]; if(a[i]>=0&&!f_0) { index_1_0=i; f_0=true; } if(a[i]>=1000&&!f_10) { index_1_10=i; f_10=true; } } cin>>M; for(int i=0;i<M;i++) { cin>>b[i]; if(b[i]<=0&&!t_0) { index_2_0=i; t_0=true; } if(b[i]<=1000&&!t_10) { index_2_10=i; f_10=true; } } for(int i=0;i<=index_1_0;i++) { for(int j=0;j<=index_2_10;j++) { if(a[i]+b[j]<1000) break; if(a[i]+b[j]==T) { cout<<"YES"; return 0; } } } for(int i=index_1_0;i<=index_1_10;i++) { for(int j=index_2_10;j<=index_2_0;j++) { if(a[i]+b[j]<1000) break; if(a[i]+b[j]==T) { cout<<"YES"; return 0; } } } for(int i=index_1_10;i<N;i++) { for(int j=index_2_0;j<M;j++) { if(a[i]+b[j]<1000) break; if(a[i]+b[j]==T) { cout<<"YES"; return 0; } } } cout<<"NO"; } Edited by author 28.06.2013 11:46 |
|
|