Форум программистов, компьютерный форум CyberForum.ru

Вычислить таблицу значений функции, используя switch в паре с break, оператор перехода goto - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Как записать функцию arccrg? http://www.cyberforum.ru/cpp-beginners/thread682097.html
Как записать функцию arccrg и плиз чтоо это такое(проста лабу сделал,а вот что это за триногометрическая функция незнаю=))?
C++ Не работают функции удаления и добавления данных в класс не работают функции удаления страны и добавления.. помогите исправить ошибки..просто срочно нужно.. #include<math.h> #include<stdio.h> #include<stdlib.h> #include<conio.h> #include<time.h> #include<dos.h> http://www.cyberforum.ru/cpp-beginners/thread682092.html
C++ Найти все корни уравнения на заданном интервале
Помогите написать программу буду очень признателен) В ходе выполнения работы необходимо создать программу, которая находит все корни уравнения на заданном интервале с заданной точностью (задается пользователем). Программа должна выводить список корней (при этом корни не должны повторяться) либо выводить соответствующее сообщение, если корней нет. ctg(x)*sin((x^3)/2)+1=0
Выведите на экран все четырехразрядные числа, в записи которых нет одинаковых цифр C++
Помогите написать код,очень Вас прошу.. вот условие: Выведите на экран все четырехразрядные числа, в записи которых нет одинаковых цифр. Заранее ОЧЕНЬ благодарю всех,кто сможет хоть чем-то мне помочь!
C++ Поиск наименьших двух элементов массива или алгоритм Хаффмана http://www.cyberforum.ru/cpp-beginners/thread682083.html
Приветствую! Дали задачу, сделать прогу в котором изначально есть массив из 12 элементов a1, a2...an с разными вероятностями, общая сумма которых составляет единицу. Нужно сделать следующее: 1. Вывести массив (я использую StringGrid) (сделано) 2. Упорядочить массив по убыванию (сделано) 3. Построить кодовое дерево по методу Хаффмана То есть, как сделать, чтобы из уже отсортированного...
C++ C++ 11 конструктор переноса && Кто-нибудь может мне пояснить или дать ссылку на информацию о rvalue reference на русском языке, а то на английском что-то не всё могу понять. подробнее

Показать сообщение отдельно
Jony Wocker
45 / 45 / 2
Регистрация: 19.11.2009
Сообщений: 362

Вычислить таблицу значений функции, используя switch в паре с break, оператор перехода goto - C++

27.10.2012, 22:57. Просмотров 663. Ответов 3
Метки (Все метки)

Доброго вам времени суток.
Есть самое бредовое задание которое я только видел в своей жизни.
Написать программу, используя операторы переключения switch в паре с оператором break, оператор перехода goto.

Вычислите таблицу значений функции
Y=f1(x), если xЄX1,
Y=f2(x), если xЄX2,
Y=f3(x), если xЄX3,
Y=f4(x), если xЄX4.
для целочисленных значений аргумента x из интервала [Хн,Хк]. Множе-ства Х1,Х2,Х3,Х4 и функции f1,f2,f3,f4.
Хн=0; Хк=30.
Х1 - четные числа из интервала [10,20]
Х2 - нечетные числа из интервала [10,20]
Х3 - [1,8]
Х4 - остальные числа

f1(x)=Pi*sin(Pi*x/3),
f2(x)=ex/10+2
f3(x)=корень(x3+4)
f4(x)=cos2 модуль(x)

Код рабочий, но он тупой.
Могли бы вы мне помочь его изменить. Может можно было его написать короче и боле логичным.

C++
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
#include <iostream>
#include <math.h>
#define P 3.1415926535 //Число Пи
using namespace std;
 
void masv(double *m, int n,char *s) //Ф-ция для корректного вывода значений. 
{                                                           //Создавалась для метки x1
    
    for (int i=0;i<=n;i++)
    {
        cout<<s<<m[i]<<endl;
    }
}
 
void main(){
    setlocale(LC_ALL,"rus"); 
    const int n=30;  
    int x;
    double a1[n],a2[n],a3[n],a4[n+1];//Массивы для значений.
    int ix1=0,ix2=0,ix3=0,ix4=0; //Для индексов массива.
    
m1:int mn;
    cout<<"Ввыберите диапозон значений"<<endl;
    cout<<"1: [10;20]"<<endl<<"2:[1;8]"<<endl<<"3:[0;30]"<<endl<<"4: Выход"<<endl;
    cout<<">>>";
    cin>>mn;
    if(mn<=4 && mn>=1) 
    { 
        system("cls");
    switch(mn)
    {
    case 1: goto x1; break;
    case 2: goto x2; break;
    case 3: goto x3; break;
    case 4: exit(1); break;
    }
    }
    else
    {
        cout<<"Вы ввели неверный диапозон"<<endl;
        cout<<"Ваш ввод: "<<mn<<endl;
        goto m1; //Если неверно, то будет простить повторный ввод.
    }
 
x1:for(x=10;x<=20;x++) //Пределы Х1 и Х2 совпадают
   {
       if (x%2==0) //Х1
       {
 
           a1[ix1]=P*sin(P*x/3.);
           ix1++;
 
       }
       else //Х2
       {
           a2[ix2]=exp(x/10.+2.);
           ix2++;
       }
   }
 
   masv(a1,ix1,"f1(x)= "); //Вызов  ф-ции вывода массива
   cout<<endl;
   masv(a2,ix2,"f2(x)= ");
   goto m2; //Конец программы
   //////////////////////////////////////////////////////////////////////////
x2:for (x=1;x<=8;x++)
   {
       a3[ix3]=sqrt(pow((double)x,3)+4);
       ix3++;
   }
   masv(a3,ix3,"f3(x)= ");
   goto m2; //Конец программы
   //////////////////////////////////////////////////////////////////////////
x3: for(x=0;x<=30;x++)
    {
        a4[ix4]=pow(cos(fabs((double)x)),2);
        ix4++;
    }
    masv(a4,ix4,"f3(x)= ");
    
    //////////////////////////////////////////////////////////////////////////
    m2:     system("pause");
 
 
 
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru