Yaswanth Kummar Ответов: 4

Расчет стоимости билета в кино...получение неправильного вывода


Расчет билетов в кино

В мультиплексном театре объявлена дисконтная схема, по которой при массовом бронировании более 20 билетов предоставляется скидка в размере 10% от общей стоимости билетов, а при предъявлении специальной купонной карты-скидка в размере 2% от общей стоимости билетов. Разработайте программу, чтобы найти общую стоимость в соответствии со схемой. Стоимость билета Королевского класса составляет 75 рупий, а королевского-150 рупий. Напитки также можно заказать, заплатив дополнительно 50 рупий за каждого участника.

Подсказка: k-king и q-queen, и вы должны забронировать минимум 5 билетов и максимум 40 одновременно. Если не удается отобразить "минимум 5 и максимум 40 билетов". Если circle задано значение, отличное от 'k' или 'q', то выход должен быть "недопустимым входом".

Стоимость билета должна быть напечатана ровно до двух знаков после запятой.

Пример Ввода 1:
Введите номер билета:35
Вы хотите освежиться:y
У вас есть код купона:y
Войти в круг:к

Пример Вывода 1:
Стоимость билета:4065.25

Что я уже пробовал:

import java.util.*;

public class CinemaTicket {
    public static void main(String[] args) {
       int t,refe;
        double rate,sum,sum1,sum2,sum3;
        String cou,ref,circle;
        Scanner s = new Scanner(System.in);
        System.out.println("Enter the no of ticket:");
        t = s.nextInt();
        if (t<5 && t> 40) 
        {
            System.out.println("Minimum of 5 and Maximum of 40 tickets");
        }

        System.out.println("Do you want refreshment:");
        ref = s.next();
        System.out.println("Do you have a coupon code:");
        co = s.next();
        System.out.println("Enter the circle:");
        circle = s.next();
        if (circle.equals("k")) {
            cost = t * 75;
        } else if (circle.equals("q")) {
            total = no * 150;
        } else {
            System.out.println("Invalid Input");
        }
        if (t> 20) {
            sum = ((0.1) * cost);
            sum1 = cost- sum;
            if (cou.equals("y")) {
                sum2 = ((0.2) * cost);
                sum3 = sum1 - sum2;
                if (ref.equals("y")) {
                    refe = t* 150;
                    rate = sum3 + refe;
                } else {
                    rate = sum3;
                }
            } else {
                rate = sum1;
            }
        } else {
            rate = cost;
        }
        System.out.printf("Ticket cost %.2f:",+rate);
    }
}

Richard MacCutchan

В чем же вопрос?

Yaswanth Kummar

Мой результат отличается от ожидаемого результата ...
Если мы дадим купон =n
Он не выполняет ref и непосредственно печатает результат

Richard MacCutchan

Итак, мы должны угадать, каков ожидаемый результат?

Richard MacCutchan

Что я могу сказать, так это то, что приведенный выше код даже не будет компилироваться. Посмотрите на линию follpwing } else if (circle.equals("q")) {; у вас есть две переменные, которые нигде не определены. И со всеми этими различными переменными неудивительно, что ответ не получается правильным. вы должны начать с количества билетов и применить стоимость, основанную на выбранных местах. Это дает общую валовую стоимость. Затем примените любые скидки, основанные на купонах. И, наконец, примените любые дополнительные услуги (напитки и т. д.). Это должно дать окончательную чистую стоимость.

Patrice T

А у вас есть вопрос или проблема ?

Yaswanth Kummar

Мой результат отличается от ожидаемого результата ...
Если мы дадим купон =n
Он не выполняет ref и непосредственно печатает результат

4 Ответов

Рейтинг:
2

Member 14781830

import java.util.*;
public class CinemaTicket
{
    public static void main(String args[])
    {
        int no;
        double cost,total=0;
        String ref,co,cir,cl;
        Scanner sc=new Scanner(System.in);
        System.out.println("Enter the no of ticket:");
        no=sc.nextInt();
        System.out.println("Do you want refreshment:");
        ref=sc.next();
        System.out.println("Do you have coupon code:");
        co=sc.next();
        System.out.println("Enter the circle:");
        cir=sc.next();
        if(no<5 || no>40)
        {
            System.out.println("Minimum of 5 and Maximum of 40 Tickets");
            return;
        }
        if(cir.charAt(0) == 'k')
            cost=75*no;
        else if(cir.charAt(0) == 'q')
            cost=150*no;
        else
        {
         System.out.println("Invalid Input");
         return;
        }
        total=cost;
        if(no>20)
            cost= cost - ((0.1)*cost);
        total=cost;
        if(co.charAt(0)== 'y')
            total= cost - ((0.02)*cost);
        if(ref.charAt(0)== 'y')
            total += (no*50);
        System.out.format("Ticket cost:%.2f",total);
    }
}


Рейтинг:
1

Patrice T

Цитата:
...получение неправильного вывода

Ваш код ведет себя не так, как вы ожидаете, или вы не понимаете, почему !

Существует почти универсальное решение: запускайте свой код на отладчике шаг за шагом, проверяйте переменные.
Отладчик здесь, чтобы показать вам, что делает ваш код, и ваша задача-сравнить с тем, что он должен делать.
В отладчике нет никакой магии, он не знает, что должен делать ваш cpde, он не находит ошибок, он просто помогает вам, показывая, что происходит. Когда код не делает того, что ожидается, вы близки к ошибке.
Чтобы увидеть, что делает ваш код: просто установите точку останова и посмотрите, как работает ваш код, отладчик позволит вам выполнять строки 1 на 1 и проверять переменные по мере их выполнения.

Отладчик - Википедия, свободная энциклопедия[^]

Освоение отладки в Visual Studio 2010 - руководство для начинающих[^]
Базовая отладка с помощью Visual Studio 2010 - YouTube[^]

http://docs.oracle.com/javase/7/docs/technotes/tools/windows/jdb.html[^]
https://www.jetbrains.com/idea/help/debugging-your-first-java-application.html[^]

Отладчик здесь только для того, чтобы показать вам, что делает ваш код, и ваша задача-сравнить его с тем, что он должен делать.

[Обновление]
Цитата:
Мой результат отличается от ожидаемого результата ...
Если мы дадим купон =n
Он не выполняет ref и непосредственно печатает результат

Это потому, что это то, что вы сказали своему коду делать !
Ref-код не выполняется, если coupon="n", потому что ref-код" находится внутри кода coupon="y".


Рейтинг:
0

OriginalGriff

Компиляция не означает, что ваш код верен! :смеяться:
Подумайте о процессе разработки как о написании электронного письма: успешная компиляция означает, что вы написали электронное письмо на правильном языке - например, на английском, а не на немецком, - а не то, что письмо содержало сообщение, которое вы хотели отправить.

Итак, теперь вы входите во вторую стадию разработки (на самом деле это четвертая или пятая, но вы перейдете к более ранним стадиям позже): тестирование и отладка.

Начните с рассмотрения того, что он делает, и как это отличается от того, что вы хотели. Это важно, потому что это дает вам информацию о том, почему он это делает. Например, если программа предназначена для того, чтобы позволить пользователю ввести число, а он удваивает его и печатает ответ, то если ввод / вывод был таким:

Input   Expected output    Actual output
  1            2                 1
  2            4                 4
  3            6                 9
  4            8                16
Тогда совершенно очевидно, что проблема заключается в бите, который удваивает его - он не прибавляет себя к себе или умножает его на 2, он умножает его на себя и возвращает квадрат входного сигнала.
Таким образом, вы можете посмотреть на код, и очевидно, что он находится где-то здесь:
int Double(int value)
   {
   return value * value;
   }

Как только у вас появится идея, что может пойти не так, начните использовать отладчик, чтобы выяснить, почему. Поместите точку останова в первую строку метода и запустите приложение. Когда он достигнет точки останова, отладчик остановится и передаст управление вам. Теперь вы можете запускать свой код построчно (так называемый "одноступенчатый") и просматривать (или даже изменять) содержимое переменных по мере необходимости (черт возьми, вы даже можете изменить код и повторить попытку, если вам это нужно).
Подумайте о том, что должна делать каждая строка кода перед ее выполнением, и сравните это с тем, что она действительно делала, когда вы использовали кнопку "Step over" для выполнения каждой строки по очереди. Он сделал то, что вы ожидали? Если да, то переходите к следующей строке.
Если нет, то почему? Чем это отличается?
Надеюсь, это поможет вам определить, в какой части этого кода есть проблема и в чем она заключается.
Это навык, и его стоит развивать, поскольку он помогает вам как в реальном мире, так и в развитии. И, как и все навыки, он только улучшается при использовании!


Рейтинг:
0

Member 14871636

импорт java.util.Сканер;
импорт java.text.DecimalFormat;

общественный класс CinemaTicket {

публичный статический пустота главный(строка[] аргументы) {

инт noTicket;
двойная сумма = 0,Стоимость;
Строки Реф, Колорадо , круг;
Сканер s = новый сканер(System.in);
System.out.println("введите номер билета:");
noTicket = С. nextInt();
if (noTicket < 5 || noTicket > 40) {
System.out.println("минимум 5 и максимум 40 билетов");
System.exit(0);
}
System.out.println("вы хотите освежиться:");
справ = С. далее();
System.out.println("у вас есть код купона:");
со = ов.далее();
System.out.println("войдите в круг:");
круг = С. далее();
if(circle.charAt(0) == 'k')
стоимость=75*noTicket;
остальное, если(круг.используя метод charat(0) == 'Q', то)
стоимость=150*noTicket;
еще
{
System.out.println("неверный ввод");
вернуть;
}
общая стоимость;
если(noTicket>20)
стоимость= стоимость - ((0.1)*стоимость);
общая стоимость;
if(co.charAt(0)== 'y')
Итого= стоимость - ((0,02)*стоимость);
if(ref.charAt(0)== 'y')
итого += (noTicket*50);
System.out.format("стоимость билета:%.2f",всего);
}
}


CHill60

Необъяснимый, неформатированный дамп кода - это не очень хорошее решение.