Help Ashu

Ashu and Shanu are best buddies. One day Shanu gives Ashu a problem testing his intelligence. He gives him an array of N natural numbers and asks him to solve the following queries:-

Query 0:- modify the element present at index i to x.
Query 1:- count the number of even numbers in range l to r inclusive.
Query 2:- count the number of odd numbers in range l to r inclusive.

Example:

Input: n = 6, a[n] = {1, 2, 3, 4, 5, 6},q = 4,queries = {{1, 2, 5}, {2, 1, 4}, {0, 5, 4}, {1, 1, 6}}

Output:

2 2 4

Approach:

C++

#include <bits/stdc++.h>
using namespace std;
int arr[1000001];
int tree[400004];
void build(int nodeint startint end)
{
    if (start == end)
    {
        tree[node] = arr[start];
        return;
    }
    int mid = (start + end) / 2;
    build(2 * nodestartmid);
    build(2 * node + 1mid + 1end);
    tree[node] = tree[2 * node] + tree[2 * node + 1];
}
int query(int nodeint startint endint lint r)
{
    if (r < start || l > end)
        return 0;
    if (l <= start && r >= end)
        return tree[node];
    int mid = (start + end) / 2;
    int p1 = query(2 * nodestartmidlr);
    int p2 = query(2 * node + 1mid + 1endlr);
    return p1 + p2;
}
void update(int nodeint startint endint indexint val)
{
    if (start == end)
    {
        tree[node] = tree[node] - arr[start] + val;
        arr[index] = val;
        return;
    }
    int mid = (start + end) / 2;
    if (index <= mid && start <= index)
        update(2 * nodestartmidindexval);
    else
        update(2 * node + 1mid + 1endindexval);
    tree[node] = tree[2 * node] + tree[2 * node + 1];
}

void helpAshu(int nint qvector<vector<int>> &queries)
{

    for (int i = 0i < qi++)
    {
        int x = queries[i][0]y = queries[i][1]z = 
queries[i][2];

        if (x == 0)
        {
            if (z & 1)
                update(11ny0);
            else
                update(11ny1);
        }
        else if (x == 2)
        {
            cout << z - y + (y != z ? 1 : 0) -
                        query(11nyz)
                 << "\n";
        }
        else
            cout << query(11nyz<< "\n";
    }
}
int main()
{
    int n = 6;
    int a[n] = {123456};
    int q = 4;
    vector<vector<int>> queries = {{125},
                                   {214},
                                   {054},
                                   {116}};
    for (int i = 1i <= ni++)
    {
        if (a[i - 1] & 1)
            arr[i] = 0;
        else
            arr[i] = 1;
    }
    build(11n);

    helpAshu(nqqueries);

    return 0;
}


No comments:

Post a Comment