Top.Mail.Ru
Ответы

C++ Кто то сможет объяснить, почему конструкция switch срабатывает не по плану?

#include <iostream>
using namespace std;

int main(int argc, char** argv) {

setlocale(LC_ALL, "Rus");
int x,y,s;
cout<<"Введите координату x:";
cin>>x;
cout<<"Введите координату y:";
cin>> y;
switch(x*y)
case 1: {
x*y <= 12;
cout<<"Эти координаты нам подходят!";
break;
case 2:
x*y >= -12;
cout<<"Эти координаты нам подходят!";
break;
}

cout<<"Yes"<<endl;

system("Pause");
return 0;
}

Вот такой не сложный код, вопрос в том, что конструкция switch срабатывает только если вводить данные 1 и 2 или 2 и 1, хотя в условии стоит до 12. я пробовал повышать ещё. а при вводе 3 и 4 не срабатывает, почему?

По дате
По рейтингу
Аватар пользователя
Новичок

Ты же указал в коде.
если x * y равно case 2: то исполняй, и так же про 1

Аватар пользователя
Гений

Можно диапазон преобразовать в число для switch.
switch ( (x*y<=-12) + (x*y<12) )
{
case 0: ;
case 2: эти координаты подходят; break;
default: эти не подходят;
}

если число <= -12 срабатывают два условия 1+1
если число <12 но больше -12 срабатывает одно условие 0+1
если число >=12 не срабатывает ни одно условие 0+0

Аватар пользователя
Мудрец

Ты неправильно понимаешь суть инструкции switch.

12345678
 switch ( <выражение> ) 
{
  case <значение 1>:
    <инструкции 1>
  case <значение 2>: 
    <инструкции 2> 
  ...
} 

В зависимости от ЗНАЧЕНИЯ выражения управление передаётся на метку case с этим значением. Обрати внимание, что это именно передача управления (goto), то есть после выполнения <инструкции 1> будут выполнены и <инструкции 2>. Чтобы этого избежать, в конце <инструкции 1> ставят break;

Теперь смотрим на твой код.

123456789
 switch(x*y) 
case 1: 
{ 
  ...
  break; 
case 2: 
  ...
  break; 
}  

Прежде всего обращу внимание на странное расположение фигурных скобок. Это работает ТОЛЬКО потому, что case является меткой, то есть не влияет на группировку операторов. Общепринято такое расположение:

123456789
 switch(x*y)  
{
  case 1:  
    ... 
    break;  
  case 2:  
    ... 
    break;  
}  

Вычисляется x*y и в зависимости от ЗНАЧЕНИЯ выполняются инструкции соответствующей метки case. Поскольку имеются case только для значений 1 и 2, то и выполняются инструкции ТОЛЬКО если x*y равно 1 или 2.

Возникает вопрос, как добиться того, что хочет автор. Инструкция switch для этого совершенно не подходит, потому что у case должно быть константное выражение, а перебирать все возможные значения x*y не представляется возможным. Нужно использовать if:

12345678
 if(x*y <= 12)
{
  cout<<"Эти координаты нам подходят!";
}
else if(x*y >= -12)
{
  cout<<"Эти координаты нам подходят!";
}  
Аватар пользователя
Мастер

Итоговый код:

#include <iostream>
using namespace std;

int main(int argc, char** argv) {
setlocale(LC_ALL, "Rus");
int x,y,s;
cout<<"Введите координату x:";
cin>>x;
cout<<"Введите координату y:";
cin>> y;
switch(x*y) {
case 1: {
if (x*y <= 12) {
cout<<"Эти координаты нам подходят!";
}
break;
}
case 2: {
if (x*y >= -12) {
cout<<"Эти координаты нам подходят!";
}
break;
}
default: {
cout<<"Эти координаты нам не подходят!";
break;
}
}
cout<<endl;
system("Pause");
return 0;
}

Аватар пользователя
Оракул

Где стоит до 12?