help plz

Pages: 123
Jun 10, 2019 at 7:27am
We have been given an array of size n , and two integers k and x;
Now, We can perform the following operation any number of times (including zero):
1.Pick exactly k elements from array.
2.Xor the k chosen elements with x in the array.

Each element may be picked any number of times in different operations.

We have to find maximum sum of array we can have at the end if we perform the operations optimally.

Please help me out in these guys.
I have absolutely no clue.


Jun 10, 2019 at 8:59am
what does xor do to a number's value?
its a fancy bit-flipper. So you want to flip high order bits from 0 to 1. as many as you can without making numbers smaller.
but there is a monkey wrench: they are integers you said, not unsigned integers, so some bit flips will make negative numbers which will decrease your sum. You want to avoid that as well.
Jun 10, 2019 at 9:28am
@joinin only positive integers.

and how can we find out how many I have to perform the operations?
Last edited on Jun 10, 2019 at 10:17am
Jun 10, 2019 at 1:00pm
the numbers are unsigned integers
Jun 10, 2019 at 1:03pm
https://www.codechef.com/JUNE19B/problems/LENTMO
here is the link to question for better comprehension
Jun 10, 2019 at 2:29pm
anybody knows the approach?
for partial?
Jun 10, 2019 at 3:16pm
again, its a bit flipper. ignoring negatives now, its still the same... just easier.
sort the input. while your xor flips high order bits for more than 50% of the next K, do it. unclear to me, do you resort and repeat or proceed until the while exits, then resort and repeat until the first K can't be improved? Are these integers bucket sortable (that tends to beat std::sort)? If not, is a 'already almost sorted' algorithm faster (eg shell sort is faster the closer arrays are to already sorted)? something like this? Tweaking the sort is optional as it takes unusual data to beat std::sort. Its really only worth it if you can bucket, because that gives you lift twice for repeats (repeated values check once for xor better is more efficient as it can skip the duplicates easier).
Last edited on Jun 10, 2019 at 3:20pm
Jun 10, 2019 at 4:43pm
If anybody have good test cases, please tell.
Jun 10, 2019 at 5:57pm
I have wrote my code , but it is giving WA.
Can anyone provide some test cases.
Jun 10, 2019 at 6:42pm
@lame
I think this case might help you

5
16 20 11 11 11
4
11

output : 91
Jun 10, 2019 at 7:02pm
@Dum, can you explain how this gives 91?
like each step
Jun 10, 2019 at 7:11pm
@theKlaw
sure.
step - 1 : (16 ^ 11) ( 20) (11 ^ 11) (11 ^ 11) (11 ^ 11)
27 20 0 0 0

step - 2 : (27) (20 ^ 11) (0 ^ 11) (0 ^11) (0 ^ 11)
27 31 11 11 11

27 + 31 + 11 + 11 + 11 = 91
Jun 11, 2019 at 8:25am
@hdude0164
if you need testcases i will give but i can't share my code
Jun 11, 2019 at 8:34am
Guys,
Daily limit of my PM is exceeded so i can't reply through PM

@abc123xyz
replace this with
1
2
3
4
#include <bits/stdc++.h>
using namespace std;

typedef __int128_t ll;


this

1
2
3
4
5
6
#include <bits/stdc++.h>
using namespace std;
#include <boost/multiprecision/cpp_int.hpp>
using namespace boost::multiprecision;

typedef int128_t ll;
Jun 11, 2019 at 8:38am
@Dum, what is the concept you are applying to get 100 points ?
Any small hint would also be appreciated or even if you could drop a direction to approach,
Thanks !
Jun 11, 2019 at 8:40am
yes....help us finding the pattern
Jun 11, 2019 at 8:41am
@despo
this is not a pattern question.
Jun 11, 2019 at 8:42am
@Dum small hint plz
Jun 11, 2019 at 8:42am
@maxdaen
from given n and k try to find the minimum number of values you can xor with
Last edited on Jun 11, 2019 at 8:43am
Jun 11, 2019 at 8:48am

@Dum, I didnt get you, pardon me.
If you dont mind , could you please explain you point with a little example, if possible.
Thanks.
Last edited on Jun 13, 2019 at 8:22am
Pages: 123