С Новым годом! Форум программистов, компьютерный форум, киберфорум
С++ для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.97/29: Рейтинг темы: голосов - 29, средняя оценка - 4.97
2 / 2 / 0
Регистрация: 28.05.2013
Сообщений: 11

Как вывести результаты расчёта в виде таблицы?

25.11.2013, 07:54. Показов 5726. Ответов 7
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемые, программисты! Подскажите, пожалуйста, как реализовать в программе вывод в виде таблицы значений скорости, пути, ускорения при различных углах α?
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
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <math.h>
main()
{
setlocale(LC_ALL,"Rus");
float const  p=3.141592653589;
    int i;
    float S,V,j,L,R,n,AL,OM,RR,LM,ALF;
    printf("Программа расчёта пути, скорости, ускорения ползуна.\n");
    printf("Введите длину шатуна L, mm: ");
    scanf("%f",&L);
    printf("Введите радиус кривошипа R, mm: ");
    scanf("%f",&R);
    printf("Введите частоту вращения кривошипа n, об/мин: ");
    scanf("%f",&n);
          LM=R/L; // коэффициент длины шатуна
    printf(" L=%f мм\n R=%f мм\n n=%f об/мин\n LM=%f\n",L,R,n,LM);
          OM=p*n/30; // частота вращения кривошипа, рад^-1
          RR=R*0.001; // перевод мм в м
    
    for (int i=0;i<72;i++)
          AL=i*5;
          ALF=(p/180)*AL; // угол в радианах
 
          S=R*(1-cos(ALF)-(LM/4)*(1-cos(2*ALF)));
          V=OM*RR*(sin(ALF)-(LM/2)*sin(2*ALF));
          j=-OM*OM*RR*(cos(ALF)-LM*cos(2*ALF));
     printf(" AL=%f\n ALF=%f\n S=%f\n V=%f\n j=%f\n",AL,ALF,S,V,j);
getch();
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
25.11.2013, 07:54
Ответы с готовыми решениями:

Результаты вычислений вывести в виде таблицы с заголовком
Задание 1!!!!:Результаты вычислений вывести в виде таблицы с заголовком. Вычисленные значения ряда сравнить со значением функции f=e. ...

Рассчитать значение функции и вывести результаты в виде таблицы
Вывести на экран таблицу значений функции Y(x) и ее разложения в ряд S(x) с точностью ε . Вывести число итераций, необходимое для...

Результаты вывести в виде таблицы с заголовком в порядке занятых мест
Результаты соревнований по прыжкам в длину определяются по сумме двух попыток. В протоколе для каждого учасниа указываются фамилия,...

7
 Аватар для ПерС
587 / 490 / 371
Регистрация: 05.11.2013
Сообщений: 1,271
Записей в блоге: 6
25.11.2013, 09:25
измени printf и добавь ширину/точность
C
1
printf("%8.2f %8.2f %8.2f %8.2f %8.2f\n",AL,ALF,S,V,j);
или тебе как в Екселе таблицу рисовать?
1
46 / 46 / 18
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 10:25
Цитата Сообщение от And_r3 Посмотреть сообщение
float const *p=3.141592653589;
В заголовочном файле math.h уже есть константа M_PI.
А для аккуратного вывода, имхо, удобнее использовать std::cout с модификациями setprecision и setw, которые подключаются через #include <iomanip>.
1
2 / 2 / 0
Регистрация: 28.05.2013
Сообщений: 11
25.11.2013, 19:30  [ТС]
Цитата Сообщение от ПерС Посмотреть сообщение
или тебе как в Екселе таблицу рисовать?
Да, мне нужно как в Екселе нарисовать. Большое спасибо, за подсказки, некоторые из них я учёл:
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
#include <stdio.h>
#include <conio.h>
#include <iostream>
#include <math.h>
main()
{
setlocale(LC_ALL,"Rus");
     int i;
     float S,V,j,L,R,n,AL,OM,RR,LM,ALF;
     printf("Программа расчёта пути, скорости, ускорения ползуна.\n");
     printf("Введите длину шатуна L, mm: ");
     scanf("%f",&L);
     printf("Введите радиус кривошипа R, mm: ");
     scanf("%f",&R);
     printf("Введите частоту вращения кривошипа n, об/мин: ");
     scanf("%f",&n);
           LM=R/L; // коэффициент длины шатуна
     printf(" L=%8.2f мм\n R=%8.2f мм\n n=%8.2f об/мин\n LM=%8.2f\n",L,R,n,LM);
           OM=M_PI*n/30; // частота вращения кривошипа, рад^-1
           RR=R*0.001; // перевод мм в м
     
     for (int i=0;i<72;i++)
           AL=i*5;
           ALF=(M_PI/180)*AL; // угол в радианах
 
           S=R*(1-cos(ALF)-(LM/4)*(1-cos(2*ALF)));
           V=OM*RR*(sin(ALF)-(LM/2)*sin(2*ALF));
           j=-OM*OM*RR*(cos(ALF)-LM*cos(2*ALF));
      printf(" AL=%8.2f\n ALF=%8.2f\n S=%8.2f\n V=%8.2f\n j=%8.2f\n",AL,ALF,S,V,j);
getch();
}
Цитата Сообщение от Hunter13ua Посмотреть сообщение
А для аккуратного вывода, имхо, удобнее использовать std::cout с модификациями setprecision и setw, которые подключаются через #include <iomanip>.
Не совсем понял как?
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
#include <iostream>
#include <math.h>
#include <iomanip>
int main()
{
setlocale(LC_ALL,"Rus");
     int i;
     float S,V,j,L,R,n,AL,OM,RR,LM,ALF;
     std::cout <<"Программа расчёта пути, скорости, ускорения ползуна.\n";
     std::cout <<"Введите длину шатуна L, mm: ";
     scanf("%f",&L);
     std::cout <<"Введите радиус кривошипа R, mm: ";
     scanf("%f",&R);
     std::cout <<"Введите частоту вращения кривошипа n, об/мин: ";
     scanf("%f",&n);
           LM=R/L; // коэффициент длины шатуна
     std::cout <<" L=";
     std::cout << std::setprecision(2) << L << '\n'; std::cout << std::fixed;
     std::cout <<" R=";
     std::cout << std::setprecision(2) << R << '\n'; std::cout << std::fixed;
     std::cout <<" n=";
     std::cout << std::setprecision(2) << n << '\n'; std::cout << std::fixed;
     std::cout <<" LM=";
     std::cout << std::setprecision(2) << LM << '\n'; std::cout << std::fixed;
           OM=M_PI*n/30; // частота вращения кривошипа, рад^-1
           RR=R*0.001; // перевод мм в м
     
     for (int i=0;i<72;i++)
           AL=i*5;
           ALF=(M_PI/180)*AL; // угол в радианах
           
           S=R*(1-cos(ALF)-(LM/4)*(1-cos(2*ALF)));
           V=OM*RR*(sin(ALF)-(LM/2)*sin(2*ALF));
           j=-OM*OM*RR*(cos(ALF)-LM*cos(2*ALF));
      std::cout <<" AL=";
      std::cout << std::setprecision(2) << AL << '\n'; std::cout << std::fixed;
      std::cout <<" ALF=";
      std::cout << std::setprecision(2) << ALF << '\n'; std::cout << std::fixed;
      std::cout <<" S="; 
      std::cout << std::setprecision(2) << S << '\n'; std::cout << std::fixed;
      std::cout <<" V=";
      std::cout << std::setprecision(2) << V << '\n'; std::cout << std::fixed;
      std::cout <<" j=";
      std::cout << std::setprecision(2) << j << '\n'; std::cout << std::fixed;
  system ("pause");
  return 0;
}
Не судите слишком строго: в C++ я дилетант. Так как, всё-таки, в виде таблицы оформить?
0
46 / 46 / 18
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 19:46
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
#include <iostream>
#include <math.h>
#include <iomanip>
#include <cstdio>
#include <cstdlib>
using namespace std;
int main()
{
setlocale(LC_ALL,"Rus");
     int i;
     float S,V,j,L,R,n,AL,OM,RR,LM,ALF;
     std::cout <<"Программа расчёта пути, скорости, ускорения ползуна.\n";
     std::cout <<"Введите длину шатуна L, mm: ";
     scanf("%f",&L);
     std::cout <<"Введите радиус кривошипа R, mm: ";
     scanf("%f",&R);
     std::cout <<"Введите частоту вращения кривошипа n, об/мин: ";
     scanf("%f",&n);
           LM=R/L; // коэффициент длины шатуна
        cout << endl;
     cout <<"   L   = " << setprecision(3) << fixed << setw(8) << L << endl;
     cout <<"   R   = " << setprecision(3) << fixed << setw(8) << R << endl;
     cout <<"   n   = " << setprecision(3) << fixed << setw(8) << n << endl;
     cout <<"   LM  = " << setprecision(3) << fixed << setw(8) << LM << endl;
           OM=M_PI*n/30; // частота вращения кривошипа, рад^-1
           RR=R*0.001; // перевод мм в м
 
     for (int i=0;i<72;i++)
           AL=i*5;
           ALF=(M_PI/180)*AL; // угол в радианах
 
           S=R*(1-cos(ALF)-(LM/4)*(1-cos(2*ALF)));
           V=OM*RR*(sin(ALF)-(LM/2)*sin(2*ALF));
           j=-OM*OM*RR*(cos(ALF)-LM*cos(2*ALF));
 
      cout <<"   AL  = " << setprecision(3) << fixed << setw(8) << AL << endl;
      cout <<"   ALF = " << setprecision(3) << fixed << setw(8) << ALF << endl;
      cout <<"   S   = " << setprecision(3) << fixed << setw(8) << S << endl;
      cout <<"   V   = " << setprecision(3) << fixed << setw(8) << V << endl;
      cout <<"   j   = " << setprecision(3) << fixed << setw(8) << j << endl;
        cout << endl;
 
  system ("pause");
  return 0;
}
Так, например.
1
2 / 2 / 0
Регистрация: 28.05.2013
Сообщений: 11
25.11.2013, 21:36  [ТС]
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Так, например.
Спасибо, Александр, извините, не подскажите: как реализовать вывод таблицы с значениями скорости, пути, ускорения при различных значениях угла альфа от 0 до 2-х пи, в радианах, примерно как в Microsoft Excel:
α, радПутьСкоростьУскорение
 S, ммV, мм/сj, мм/с^2
000-13,08
0,180,560,12-12,93
0,352,230,24-12,48
0,524,960,35-11,74
и т. д.?
0
46 / 46 / 18
Регистрация: 25.10.2011
Сообщений: 183
25.11.2013, 23:07
Оформлять каждому удобно по-своему. Могу посоветовать так:
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
#include <cstdlib>
#include <iostream>
#include <iomanip>
using namespace std;
 
struct data_struct {
    float a;
    float S;
    float V;
    float j;
 
    void print(void)
    {
        cout << setw(6) << a << " | "
         << setw(6) << S << " | "
         << setw(9) << V << " | "
         << setw(10) << j << " | "
         << endl;
    }
} info[10];
 
int main()
{
    for(int i = 0; i < 10; i++){
        info[i].a = ( rand() % 100 ) / 100.0;
        info[i].S = ( rand() % 1000 ) / 100.0;
        info[i].V = ( rand() % 100 ) / 100.0;
        info[i].j = -10.0 - ( rand() % 1000 ) / 100.0;
    }
    setlocale(LC_ALL,"Rus");
    cout << setw(6) << "a, рад" << " | "
         << setw(6) << "Путь" << " | "
         << setw(9) << "Скорость" << " | "
         << setw(10) <<"Ускорение" << " | "
         << endl;
    cout << setw(6) << " " << " | "
         << setw(6) << "S, мм" << " | "
         << setw(9) << "V, мм/с" << " | "
         << setw(10) <<"j, мм/с^2" << " | "
         << endl;
    for(int i = 0; i < 10; i++)
        info[i].print();
    cin.get();
    return 0;
}
1
2 / 2 / 0
Регистрация: 28.05.2013
Сообщений: 11
26.11.2013, 21:51  [ТС]
Цитата Сообщение от Hunter13ua Посмотреть сообщение
Оформлять каждому удобно по-своему. Могу посоветовать так:
Спасибо, большое!
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
26.11.2013, 21:51
Помогаю со студенческими работами здесь

Вывести результаты решения СЛАУ в виде таблицы (графические функции)
Ребят помогите пожалуйста, есть полностью рабочий и компилирующийся код для решения слау методом гаусса но решение необходимо представить...

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

Составить схему алгоритма и программу решения задачи с использованием подпрограмм. Результаты вывести в виде таблицы
Задание 3 Составить схему алгоритма и программу решения задачи с использованием подпрограмм. Результаты вывести в виде таблицы , в...

Как вывести результаты расчета с графикой в doc или rtf?
Кой как разобрался с операторами print# и write#. Беда в том что txt не совсем годится для вывода информации.

Как представить результаты выполнения команды ping в виде html-таблицы?
Всем доброго времени суток! Подскажите пожалуйста, как можно с помощью батника результаты команды ping перевести в html таблицу. в...


Искать еще темы с ответами

Или воспользуйтесь поиском по форуму:
8
Ответ Создать тему
Новые блоги и статьи
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути
Programma_Boinc 01.01.2026
Учёным и волонтёрам проекта «Einstein@home» удалось обнаружить четыре гамма-лучевых пульсара в джете Млечного Пути Сочетание глобально распределённой вычислительной мощности и инновационных. . .
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост.
Programma_Boinc 28.12.2025
Советы по крайней бережливости. Внимание, это ОЧЕНЬ длинный пост. Налог на собак: https:/ / **********/ gallery/ V06K53e Финансовый отчет в Excel: https:/ / **********/ gallery/ bKBkQFf Пост отсюда. . .
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Нашел на реддите интересную статью под названием Anyone know where to get a free Desktop or Laptop? Ниже её машинный перевод. После долгих разбирательств я наконец-то вернула себе. . .
Thinkpad X220 Tablet — это лучший бюджетный ноутбук для учёбы, точка.
Programma_Boinc 23.12.2025
Рецензия / Мнение/ Перевод Нашел на реддите интересную статью под названием The Thinkpad X220 Tablet is the best budget school laptop period . Ниже её машинный перевод. Thinkpad X220 Tablet —. . .
PhpStorm 2025.3: WSL Terminal всегда стартует в ~
and_y87 14.12.2025
PhpStorm 2025. 3: WSL Terminal всегда стартует в ~ (home), игнорируя директорию проекта Симптом: После обновления до PhpStorm 2025. 3 встроенный терминал WSL открывается в домашней директории. . .
Как объединить две одинаковые БД Access с разными данными
VikBal 11.12.2025
Помогите пожалуйста !! Как объединить 2 одинаковые БД Access с разными данными.
Новый ноутбук
volvo 07.12.2025
Всем привет. По скидке в "черную пятницу" взял себе новый ноутбук Lenovo ThinkBook 16 G7 на Амазоне: Ryzen 5 7533HS 64 Gb DDR5 1Tb NVMe 16" Full HD Display Win11 Pro
Музыка, написанная Искусственным Интеллектом
volvo 04.12.2025
Всем привет. Некоторое время назад меня заинтересовало, что уже умеет ИИ в плане написания музыки для песен, и, собственно, исполнения этих самых песен. Стихов у нас много, уже вышли 4 книги, еще 3. . .
От async/await к виртуальным потокам в Python
IndentationError 23.11.2025
Армин Ронахер поставил под сомнение async/ await. Создатель Flask заявляет: цветные функции - провал, виртуальные потоки - решение. Не threading-динозавры, а новое поколение лёгких потоков. Откат?. . .
Поиск "дружественных имён" СОМ портов
Argus19 22.11.2025
Поиск "дружественных имён" СОМ портов На странице: https:/ / norseev. ru/ 2018/ 01/ 04/ comportlist_windows/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru