Problem
You are given an array A containing N integers. Find if it is possible to rearrange the elements of the array such that the parity of the sum of each pair of adjacent elements is equal (formally, for each ).
Here, parity refers to the remainder obtained when a number is divided by 2 (i.e. ).
Input format
- The first line contains T denoting the number of test cases. The description of T test cases is as follows:
- For each test case:
- The first line contains N denoting the size of array A.
- The second line contains N space-separated integers A[1], A[2], ....., A[N] - denoting the elements of A.
Output format
For each test case, print "YES"(without quotes) if it is possible to reorder the array elements to satisfy the given condition and "NO"(without quotes) otherwise.
Constraints
Time Limit: 1
Memory Limit: 256
Source Limit:
Explanation
The first test case
- The given array already satisfies the required condition. Here for each
The second test case
- There is no way to reorder the elements of the given array to satisfy the required condition.
The third test case
- One possible reordering is [5, 2, 7, 2, 1]. Here for each
Code(C++):-
#include <bits/stdc++.h>
using namespace std;
int main() {
int T,N;
cin>>T;
while(T--){
cin>>N;
int A[N];
int even_count = 0,odd_count = 0;
for(int i=0;i<N;i++){
cin>>A[i];
if(A[i]%2)
odd_count++;
else
even_count++;
}
if(even_count == N || odd_count == N){
cout<<"YES\n";
continue;
}
if(abs(even_count - odd_count) <= 1){
cout<<"YES\n";
continue;
}
cout<<"NO\n";
}
}
Code(JAVA):-
import java.io.BufferedReader;
import java.io.InputStreamReader;
import java.util.*;
class TestClass {
public static void main(String args[] ) throws Exception {
//BufferedReader
String str = "";
BufferedReader br = new BufferedReader(new InputStreamReader(System.in));
str = br.readLine();
// Reading input from STDIN
int testcases = Integer.parseInt(str);
// TODO Auto-generated method stub
for(int i = 0;i < testcases; i++) {
str = br.readLine();
int len = Integer.parseInt(str);
//actual logic
String val = br.readLine();
String[] tokens = val.split(" ");
int[] ary = new int[tokens.length];
int j = 0;
for (String token : tokens){
ary[j++] = Integer.parseInt(token);
}
j = 0;
int odds = 0;
int evens = 0;
while (j< tokens.length) {
if(ary[j] % 2 == 0) {
evens++;
}else {
odds++;
}
j++;
}
if((evens ==0)||(odds ==0)||(odds == evens)) {
System.out.println("YES");
}else if((evens > odds)&&(evens - odds ==1)) {
System.out.println("YES");
}else if((odds > evens)&&(odds - evens ==1)) {
System.out.println("YES");
}else {
System.out.println("NO");
}
}
}
}
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