پاسخ سوال قطار کامیابی + کوئرا

پاسخ سوال قطار کامیابی + کوئرا
پاسخ سوال قطار کامیابی + کوئرا

پاسخ سوال قطار کامیابی + کوئرا

در این نوشته تمرین “قطار کامیابی” که در وبسایت کوئرا موجود می باشد را برای شما کاربران عزیز حل کرده ایم.

 

 

در مورد سایت کوئرا بیشتر بخوانید…

 

تمرین قطار کامیابی کوئرا + جاوا

بعد از مدت‌ها که لیته توانست با موفقیت چالش خوش‌اندام شدن را تا حدودی پشت سر بگذارد، فیته نیز کم‌کم به او علاقه‌مند شد و امروز آن‌ها می‌خواهند به اولین قرار خود بروند. لیته در نقطه a شهر زندگی می‌کند و فیته نقطه b را برای اولین قرار انتخاب کرده‌است.

در این شهر دو نوع قطار برای جا‌به‌جایی وجود دارد:

  • نوع اول: نقطه  و x + 1 را با یک مسیر دو طرفه به هم متصل می‌کند. ( به ازای هر x صحیح )
  • نوع دوم: نقطه و  را با یک مسیر دوطرفه به هم متصل می‌کند. ( به ازای هر x صحیح و k داده شده در ورودی )

هم چنین می‌دانیم فاصله طی کردن یک مسیر بین دو نقطه به ازای هر‌نوع قطار دقیقا یک دقیقه است.

وظیفه شما به عنوان دوست و رفیق لیته این است که به او بگویید زودترین زمان ممکن رسیدن لیته به محل قرار چقدر است.

ورودی سوال قطار کامیابی

 

 

خروجی سوال قطار کامیابی

 

 

حل سوال قطار کامیابی (به زبان برنامه نویسی جاوا)

import java.util.Arrays;
import java.util.Scanner;

public class Main {

    public static void main(String[] args) {
        Scanner scanner = new Scanner(System.in);
        int k = scanner.nextInt();
        int a = scanner.nextInt();
        int b = scanner.nextInt();
        int tak_tak_go = Math.abs(b-a);
        int start_point_1 = 0 ,start_point_2 =0;
        if (a>=0){
            start_point_1 = a + k - Math.abs(a%k);
            start_point_2 = a - Math.abs(a%k);
        }else{
            start_point_1 = a - a%k;
            start_point_2 = a -(k + a%k);
        }
        int end_point_1 = 0 ,end_point_2 =0;
        if (b>=0){
            end_point_1 = b + k - Math.abs(b%k);
            end_point_2 = b - Math.abs(b%k);
        }else{
            end_point_1 = b - b%k;
            end_point_2 = b -(k + b%k);
        }
        int oo1 = Math.abs(start_point_1-end_point_1);
        int oo2 = Math.abs(start_point_2-end_point_1);
        int oo3 = Math.abs(start_point_2-end_point_2);
        int oo4 = Math.abs(start_point_1-end_point_2);
        int arr [] = new int[4];
        arr[0] = oo1;
        arr[1] = oo2;
        arr[2] = oo3;
        arr[3] = oo4;
        int s1,s2,e1,e2;
        Arrays.sort(arr);
        if (arr[0] == oo1){
            s1 = start_point_1;
            e1 = end_point_1;
            s2 = start_point_2;
            e2 = end_point_2;
        }else if (arr[0] == oo2){
            s1 = start_point_2;
            e1 = end_point_1;
            s2 = start_point_1;
            e2 = end_point_2;
        }else if (arr[0] == oo3){
            s1 = start_point_2;
            s2 = start_point_1;
            e1 = end_point_2;
            e2 = end_point_1;
        }else {
            s1 = start_point_1;
            s2 = start_point_2;
            e1 = end_point_2;
            e2 = end_point_1;
        }
        int d1 = Math.abs(a-s1) + Math.abs(b-e1) + Math.abs(e1-s1)/k;
        int d2 = Math.abs(a-s1) + Math.abs(b-e2) + Math.abs(e2-s1)/k;
        int d3 = Math.abs(a-s2) + Math.abs(b-e1) + Math.abs(e1-s2)/k;
        int d4 = Math.abs(a-s2) + Math.abs(b-e2) + Math.abs(e2-s2)/k;
        int arr2[] = new int[4];
        arr2[0] = d1;
        arr2[1] = d2;
        arr2[2] = d3;
        arr2[3] = d4;
        Arrays.sort(arr2);
        if (arr2[0] < tak_tak_go){
            System.out.println(arr2[0]);
        }else{
            System.out.println(tak_tak_go);
        }

    }
}

 

 

منبع سوال : وبسایت کوئرا

 

اگر روش حل بهتری برای “تمرین قطار کامیابی” دارید برای ما ارسال کنید تا با نام خودتان به اشتراک بگذاریم.

اگر سوال خاصی را مدنظر دارید در بخش نظرات برای ما ارسال کنید تا حل آن سوال را در الویت محتوای سایت بگذاریم.

موفق باشید.

برای امتیاز به این نوشته کلیک کنید!
[کل: 0 میانگین: 0]