psbook solutions

সমস্যা ও সমাধান বই - ১ এর উপর অনুশীলন ( Practice code for Problem and Solutions Book - 1 by Mahbubul Hasan )

View the Project on GitHub

UVa 12108 - Extraordinarily Tired Students

বইয়ে একটা শর্ত বাদ দেয়া হয়েছে। তা হল প্রত্যেকে ঘুমাতে যাওয়ার আগে গুনে দেখে কতজন জেগে আছে। যদি দেখা যায় বেশিরভাগ স্টুডেন্টই ঘুমিয়ে আছে তাহলে সেও ঘুমাতে চলে যাবে।না হলে সে আরো a সময় জাগবে। অর্থাৎ তার awaken-sleeping period এর প্রথম অবস্থায় চলে যাবে।প্রত্যেক স্টুডেন্টের অবস্থা status অ্যারেতে রাখব। তারপর সব স্টুডেন্টের awaken-sleeping period এর দৈর্ঘের ল সা গু পর্যন্ত t এর লুপ চলিয়ে দেখব কতজন স্টুডেন্ট জেগে আছে। যদি সবাইজেগে থাকে তাহলে ত হলই। না থাকলে সবার পরবর্তী অবস্থা কি হবে তা status অ্যারেতে লিখে রাখব।

Time O( lcm(a[i]+b[i])*n )
Memory O(n)
Commit Time 15 Oct 2017 14:44
#include <bits/stdc++.h>

using namespace std;

int gcd(int a, int b) {
    if(a % b == 0) return b;
    else return gcd(b,a%b);
}

int lcm(int a, int b) {
    return a*b/gcd(a,b);
}

int n;
int arr[13][3];
int status[13];

//Checks how many students are awake and updates their status
//returns true if everyone is awake, false otherwise
bool update() {
    int count = 0;
    for (int i = 0; i < n; i++) {
        if(status[i] <= arr[i][0]) count++;
    }
    if(count == n) return true;
    for(int i = 0;i <= n; i++) {
        if(status[i] == arr[i][0]+arr[i][1] || (status[i] == arr[i][0] && n <= count*2)) status[i] = 1;
        else status[i]++;
    }
    return false;
}

int main() {
    int caseno = 1;
    while(1) {
        scanf("%d", &n);
        if(n == 0) break;

        int l = 1; //to hold lcm

        for(int i = 0; i < n; i++) {
            scanf("%d %d %d", &arr[i][0], &arr[i][1], &arr[i][2]);
            status[i] = arr[i][2];
            l = lcm(l, arr[i][0]+arr[i][1]);
        }
        
        bool found;
        for( int t = 1; t <= l; t++) {
            found = update();
            if(found) {
                printf("Case %d: %d\n", caseno++, t);
                break;
            }
        }
        if(!found) {
            printf("Case %d: -1\n", caseno++);
        }
    }
    return 0;
}