John and GCD list - Hackerrank



  1. John and GCD list - Hackerrank


Solution :

#include<bits/stdc++.h>

using namespace  std ;

typedef long long  ll;

typedef pair<ll, ll> Pll;

#define F first

#define S second

#define MP make_pair

#define PB push_back

#define rad(X) cout << (X) << endl

#define ASH(X) cout << (X) << " "

#define debug(x) cout << #x << " " << x << endl;

#define debug2(x,y) cout << #x << " " << x << " " << #y << " " << y << endl;

#define FOR(I,A,B) for(ll I = (A); I <= (B); I++)

#define cir(I,B,A) for(ll I = (A); I >=(B); I--)

#define MS0(X) memset((X), 0, sizeof((X)))

#define MS1(X) memset((X), -1, sizeof((X)))

#define SORT(c) (sort(c.begin(),c.end()))

#define SORT_UNIQUE(c) (sort(c.begin(),c.end()), c.resize(distance(c.begin(),unique(c.begin(),c.end()))))

#define GET_POS(c,x) (lower_bound(c.begin(),c.end(),x)-c.begin())

#define CASES int ___T; cin >> ___T; for(int cs=1;cs<=___T;cs++)

#define FAST()  ios_base::sync_with_stdio(false);cin.tie(NULL);cout.tie(NULL);

template<typename T>T gcd(T x, T y){if(y==0)return x;else return gcd(y,x%y);}

ll fx[] = {1, 1, 0, -1, -1, -1, 0, 1};

ll fy[] = {0, 1, 1, 1, 0, -1, -1, -1};

vector<ll>a,b,c;

map<ll,ll>m1,m2,m3;


/************************************************/

int LCM(ll aa,ll bb)

{

  return aa*bb/gcd(aa,bb);

}


void Execute()

{

      ll n, x, y, z;

      cin >> n;

      ll a[n];

      a[0]=0;

      FOR(i,0,n-1) cin >> a[i];



      std::vector<ll> v,v1;

      cout<<a[0]<<" ";


      FOR(i,1,n-1)

      {

         cout<<LCM(a[i-1],a[i])<<" ";

      }

      cout<<a[n-1];

      std::cout  << '\n';


}


int32_t main()

{

    //freopen("atomm.txt", "r", stdin);

    FAST();

    CASES

    {

        Execute();

    }

}




Comments

Popular Posts