28 February 2018

UVA 12149 - Feynman

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647


int main()
{
    int n,sum;
    while(sc("%d",&n)&&n)
    {
       sum = (n*(n+1)*(2*n+1))/6;
       pf("%d\n",sum);
    }

    return 0;
}

UVA 924 - Spreading The News

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647
#define lowest_int -2147483647

int visited[100001];
int parent[100001];
int headerInADay[100001];
vector<int>G[10001];

void bfs(int src)
{
    queue<int>q;
    memset(visited,0,sizeof(visited));
    memset(parent,0,sizeof(parent));

    q.push(src);
    visited[src]=1;
    headerInADay[src]=0;
    int u,v;
    while(!q.empty())
    {
        u = q.front();
        q.pop();
        for(int i=0; i<G[u].size() ; i++)
        {
            v = G[u][i];
            if(headerInADay[v] == lowest_int)
            {
                headerInADay[v] = headerInADay[u] +1;
                q.push(v);
            }
        }
    }
}


void print_path(int src)
{
    int occuer[2600];
    memset(occuer,0,sizeof(occuer));

    for(int i=0 ; i<2500 ; i++)
        if(headerInADay[i] != lowest_int)
        occuer[headerInADay[i]]++;

    int maxi = -1 ;
    int maxiDay;

    for(int i=1 ; i<2510 ; i++)
    {
       if(maxi < occuer[i])
       {
           maxi = occuer[i];
           maxiDay = i;
       }
    }
    if(G[src].size() ==0)
        pf("0\n");
    else
        pf("%d %d\n",maxi,maxiDay);


}

int main()
{
    int node,edge,test,src,n;
    sc("%d",&node);

    for(int i=0 ; i<node ; i++)
    {
        sc("%d",&edge);
        for(int j=0 ; j<edge ; j++)
        {
            sc("%d",&n);
            G[i].pb(n);
        }
    }

    sc("%d",&test);
    for(int i=1 ; i<=test ; i++)
    {
        for(int j=0 ; j<2510 ; j++)
           headerInADay[j] = lowest_int;
        sc("%d",&src);
        bfs(src);
        print_path(src);
    }
    return 0;
}


27 February 2018

UVA 11824 - A Minimum Land Price

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647

int main()
{
    int test ,p;
    sc("%d",&test);
    vector<int> data ;
    bool tooExpensive;
    ll sum;
    while(test--)
    {
        tooExpensive = false;
        while(1)
        {
            sc("%d",&p);
            if(p==0)
                break;
            data.pb(p);
        }
        sum =0;
        sort(data.begin(),data.end());
        reverse(data.begin(),data.end());
        for(int i=0 ; i<data.size() ; i++)
        {
            p = data[i];
            //pf("%d ",pow(p,i+1));
            sum += (2*pow(p,i+1));
            if(sum > 5000000)
            {
                tooExpensive = true ;
                break;
            }
        }
        if(tooExpensive){
            pf("Too expensive\n");
        }else{
           pf("%lld\n",sum);
        }

        data.clear();
    }

    return 0;
}



UVA 10905 - Children's Game

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647


struct str{
  string str;
};

bool operator < (const str & a, const str & b)
{
    return a.str + b.str > b.str + a.str ;
}

int main()
{
   int n;
   while(sc("%d",&n))
   {
       if(n==0)
        break;
        str num[55];

       for(int i=0 ; i<n; i++)
       {
           cin>>num[i].str ;
       }

       sort(num, num+n);

       for(int i=0 ; i<n ; i++)
        cout<<num[i].str ;

       cout<<endl ;
   }
    return 0;
}


UVA 530 - Binomial Showdown

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647


int main()
{

    ll n,m,res,i,num,p ;
    while(sc("%lld %lld",&n,&m)==2)
    {
        if(n==0 && m==0)
            break;
        res = 1 ;
        if(n-m < m)
            p = n-m;
        else
            p = m;
        num = n;
        for(i=1 ; i<=p ; i++,num--)
        {
            res = res * num;
            res = res/i;
        }

        pf("%lld\n",res);
    }
    return 0;
}


UVA 369 - Combinations

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647


int main()
{

    ll n,m,res,i,num,p ;
    while(sc("%lld %lld",&n,&m)==2)
    {
        if(n==0 && m==0)
            break;
        res = 1 ;
        if(n-m < m)
            p = n-m;
        else
            p = m;
        num = n;
        for(i=1 ; i<=p ; i++,num--)
        {
            res = res * num;
            res = res/i;
        }

        pf("%lld things taken %lld at a time is %lld exactly.\n",n,m,res);
    }
    return 0;
}

26 February 2018

UVA 11687 11687 - Digits

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<string>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647

int main()
{
   string str, str1 ;
   int prev,x,ln1;
   while(cin>>str)
   {
       if(str == "END")
        break;
       int ln = str.size();
       x = ln;
       if(ln==1 && str[0]=='1')
       {
           pf("1\n");
           continue;
       }
       int cnt =1 ;
       while(true)
       {
           str1 = to_string(x);
           ln1 = str1.size();
           if(ln1 == x)
           {
               pf("%d\n",cnt+1);
               break;
           }
           x = ln1 ;
           cnt++;
       }
   }
    return 0;
}


UVA 10324 Zeros and Ones

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647

int main()
{
   string str ;
   int i,j,test,minv, maxv ;
   int cnt=1 ;
   while(cin>>str)
   {
       if(str.size() == 0)
        break;
       sc("%d",&test);
       pf("Case %d:\n",cnt++);
       for(int k=1 ; k<=test; k++)
       {
           sc("%d %d",&i,&j);
           bool notSame = true ;
           minv = min(i,j);
           maxv = max(i,j);
           char ch = str[minv];
           for(int n = minv ; n<=maxv ; n++)
           {
             if(ch == str[n])
                continue ;
             else if(ch != str[n]){
                notSame = false;
                break;
             }
           }
           if(notSame)
            pf("Yes\n");
           else
            pf("No\n");
       }
   }
    return 0;
}

UVA 11661

/***
Md. Nazmul Hasan
Shahjalal University of Science & Technology,Sylhet.
hasan08sust@gmail.com
***/
#include<iostream>
#include<cstdio>
#include<stack>
#include<queue>
#include<map>
#include<vector>
#include<algorithm>
#include<cstring>
#include<sstream>
#include<cmath>
#include <iomanip>
using namespace std ;
typedef long long ll ;
typedef int in ;
typedef unsigned long long ull ;
const double pi = 2*acos(0) ;
#define maxi 40000
#define pf printf
#define sc scanf
#define pb push_back
#define MEM(x,y) (memset((x),(y),sizeof(x)))
#define MIN(x,y) ((x) < (y) ? (x) : (y))
#define MAX(x,y) ((x) > (y) ? (x) : (y))
#define load(array,size)  for(int i=0 ; i<size ; i++) cin>>array[i]  ;
#define new_line  pf("\n")
#define clear_data(array) memset(array,0,sizeof(array))
#define highest_int 2147483647

int main()
{
    int l ;
    string str ;
    while(sc("%d",&l))
    {
        if(l==0)
            break;
        cin>>str ;
        int lastD = -l;
        int lastR = -l;
        int minimumDistance = l;

        for(int i=0 ; i<l ; i++)
        {
            if(str[i] =='Z')
            {
                minimumDistance =0;
                break;
            }
            else if(str[i] == 'R')
            {
               minimumDistance = min(minimumDistance, i-lastD) ;
               lastR = i;
            }
            else if(str[i] == 'D')
            {
                minimumDistance = min(minimumDistance, i-lastR) ;
               lastD = i;
            }
        }
        pf("%d\n",minimumDistance);
    }
    return 0;
}

UVA 10679 - I Love Strings!!