Wednesday, 7 November 2018

UVA 382 - Perfection








#include<bits/stdc++.h>
using namespace std;
int main()
{
    long long n,i,j,sum,x,c=0;

    while(cin>>n)
    {
        if(n==0)
        {

            break;
        }
        if(c==0)
        cout<<"PERFECTION OUTPUT"<<endl;
        x=sqrt(n);
        if(x*x==n &&n!=1)
            sum=x;
        else
        {
            sum=0;
            x=1;
        }
        if(n!=1)
        {
            for(i=2; i*i<n; i++)
            {
                if(n%i==0)
                {
                    sum+=i+(n/i);
                    //cout<<sum<<" "<<i<<" "<<n/i<<endl;
                }
            }

        sum+=1;
        }
        //cout<<sum<<" "<<n<<endl;
        if(sum==n)
            printf("%5d  PERFECT\n",n);

        else if(sum>n)
        printf("%5d  ABUNDANT\n",n);
            //cout<<n<<" ABUNDANT"<<endl;
        else
         printf("%5d  DEFICIENT\n",n);
         c++;

    }
    cout<<"END OF OUTPUT"<<endl;
    return 0;
}

Tuesday, 6 November 2018

UVA 369 - Combinations






#include<bits/stdc++.h>
using namespace std;
int main()
{
    long long n,m,i,c,sum,x,z,y;
    while(cin>>n>>m)
    {
        if(n==0&&m==0)
            break;
        z=n-m;
        if(m>z)
        {
            x=z;
            y=m;
        }
        else
        {
            x=m;
            y=z;
        }
        sum=1;
        c=1;
        for(i=n;i>y;i--)
        {
            //cout<<i<<" "<<sum<<" "<<c<<endl;
            sum*=i;
            sum/=c;
            if(c>=x)
                break;
            c++;
        }
        cout<<n<<" things taken "<<m<<" at a time is "<<sum<<" exactly."<<endl;
    }
    return 0;
}

Sunday, 4 November 2018

UVA 272 - TEX Quotes









#include<bits/stdc++.h>
using namespace std;
int main()

{
    char s[1000000],ss[1000000];
    long long i,j,l,c,count;
    count=0;
    c=0;
    while(gets(s))
    {
        l=strlen(s);


        for(i=0; i<l; i++)
        {

            if(s[i]=='"')
            {
                c++;
                if(c%2==1)
                    cout<<"``";
                else
                    cout<<"\'\'";
            }
            else
                cout<<s[i];
        }
        cout<<endl;

    }
    return 0;
}

Saturday, 3 November 2018

UVA 264 - Count on Cantor



Solution:
#include<bits/stdc++.h>
using namespace std;

vector <long long >ar,br;
int main()
{
    long long i,j,n,a=1,b=1,c,x;
    c=1;
    for(i=1; i<=1000000; i++)
    {
        if(i%2==0)
        {
            //cout<<"x="<<endl;
            a=1;
            b=i;

            for(j=1; j<=i; j++)
            {
                ar.push_back(a);
                br.push_back(b);
                b--;
                a++;

                //cout<<"A="<<ar[c]<<" "<<br[c]<<" "<<c<<endl;
                c++;

            }

        }
        else
        {
            //cout<<"y="<<endl;
            a=i;
            b=1;
            for(j=1; j<=i; j++)
            {
                ar.push_back(a);
                br.push_back(b);
                b++;
                a--;
                //cout<<"B="<<ar[c]<<" "<<br[c]<<" "<<c<<endl;
                c++;

            }
        }
        if(c>10000009)
            break;



    }
    long long count=1;
    while(cin>>x)

    {
        cout<<"TERM "<<x<<" IS "<<ar[x-1]<<"/"<<br[x-1]<<endl;
    }
    return 0;
}