Problem
You are given an array of numbers and queries. In each query, , find of all numbers except the range .
Input format
- The first line contains two integers denoting the number of elements and denoting the number of test cases.
- The second line of each test case contains space-separated integers.
- The next lines contain two integers and .
Output format
For each test case, print the answer as described in the problem statement.
Example
Let the array be and you are given a query , then print the of all the array without the range .
Hence, the answer will be {XOR}.
Constraints
Time Limit: 1
Memory Limit: 256
Source Limit:
Code(C++):-
#include <iostream>
#include <vector>
using namespace std;
int main() {
ios_base::sync_with_stdio(false);
cin.tie(nullptr);
int n, q; cin >> n >> q;
vector<int> a(n);
for(int i = 0; i < n; i ++) cin >> a[i];
vector<int> presum(n + 1, 0);
for(int i = 0; i < n; i ++) presum[i + 1] = presum[i] ^ a[i];
int l, r;
while(q --){
cin >> l >> r;
l --, r --;
cout << (presum.back() ^ presum[r + 1] ^ presum[l]) << '\n';
}
return 0;
}
Code(JAVA):-
import java.io.BufferedReader;
import java.io.IOException;
import java.io.InputStreamReader;
import java.io.PrintWriter;
import java.util.*;
class TestClass {
public static PrintWriter out = new PrintWriter(System.out);
// copied from codeforces
public static class MyScanner {
BufferedReader br;
StringTokenizer st;
public MyScanner() {
br = new BufferedReader(new InputStreamReader(System.in));
}
String next() {
while (st == null || !st.hasMoreElements()) {
try {
st = new StringTokenizer(br.readLine());
} catch (IOException e) {
e.printStackTrace();
}
}
return st.nextToken();
}
int nextInt() {
return Integer.parseInt(next());
}
long nextLong() {
return Long.parseLong(next());
}
double nextDouble() {
return Double.parseDouble(next());
}
String nextLine(){
String str = "";
try {
str = br.readLine();
} catch (IOException e) {
e.printStackTrace();
}
return str;
}
}
static final int MAX = 100_010;
static int[] A = new int[MAX];
static int[][] prefixSum = new int[MAX][32];
public static void main(String args[] ) throws Exception {
final var scanner = new MyScanner();
final int N = scanner.nextInt();
final int Q = scanner.nextInt();
for(int i = 1; i <= N; i++){
A[i] = scanner.nextInt();
for(int b = 0; b < 32; b++){
prefixSum[i][b] = prefixSum[i-1][b];
if((A[i] & (1 << b)) != 0){
prefixSum[i][b]++;
}
}
}
for(int q = 1; q <= Q; q++){
final int l = scanner.nextInt();
final int r = scanner.nextInt();
int xor = 0;
for(int b = 0; b < 32; b++){
if((prefixSum[N][b] - (prefixSum[r][b] - prefixSum[l-1][b])) % 2 != 0){
xor |= (1 << b);
}
}
out.println(xor);
}
out.flush();
}
}
Recommended Post :-
HCL Coding Questions:-
Capgemini Coding Questions:-
iMocha coding Questions:-
Tech Mahindra coding questions:-
Unthinkable Solutions coding questions:-
- Swap the adjacent characters of the string
- Double the vowel characters in the string
- Character with their frequency
- Program to find the closest value
Must check this:-
Companies interview:-
- Swap adjacent characters
- Double the vowel characters
- Check valid parenthesis
- Print the characters with their frequencies
- Find closest value
- Word Count
- Program of CaesarCipher
- Program to find the perfect city
- Annual Day | Tech Mahindra coding question
- Find the number of pairs in the array whose sum is equal to a given target.
Full C course:-
Key points:-
- How to set limit in the floating value in python
- What is boolean data type
- How to print any character without using format specifier
- How to check that given number is power of 2 or not
- How to fix limit in double and floating numbers after dot (.) in c++
- How to print a double or floating point number in scientific notation and fixed notation
- How to take input a string in c
- How to reduce the execution time of program in c++.
Cracking the coding interview:-
Array and string:-
Tree and graph:-
Hackerearth Problems:-
- Very Cool numbers | Hacker earth solution
- Vowel Recognition | Hackerearth practice problem solution
- Birthday party | Hacker earth solution
- Most frequent | hacker earth problem solution
- program to find symetric difference of two sets
- cost of balloons | Hacker earth problem solution
- Chacha o chacha | hacker earth problem solution
- jadu and dna | hacker earth solution
- Bricks game | hacker earth problem
- Anti-Palindrome strings | hacker earth solution
- connected components in the graph | hacker earth data structure
- odd one out || hacker earth problem solution
- Minimum addition | Hackerearth Practice problem
- The magical mountain | Hackerearth Practice problem
- The first overtake | Hackerearth Practice problem
Hackerrank Problems:-
- Playing With Characters | Hackerrank practice problem solution
- Sum and Difference of Two Numbers | hackerrank practice problem solution
- Functions in C | hackerrank practice problem solution
- Pointers in C | hackerrank practice problem solution
- Conditional Statements in C | Hackerrank practice problem solution
- For Loop in C | hackerrank practice problem solution
- Sum of Digits of a Five Digit Number | hackerrank practice problem solution
- 1D Arrays in C | hackerrank practice problem solution
- Array Reversal | hackerrank practice problem solution
- Printing Tokens | hackerrank practice problem solution
- Digit Frequency | hackerrank practice problem solution
- Calculate the Nth term | hackerrank practice problem solution
Data structure:-
- Program to find cycle in the graph
- Implementation of singly link list
- Implementation of queue by using link list
- Algorithm of quick sort
- stack by using link list
- program to find preorder post order and inorder of the binary search tree
- Minimum weight of spanning tree
- Preorder, inorder and post order traversal of the tree
MCQs:-
0 Comments