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

нужно сделать трассировку. кто-нибудь знает как? - C++

Войти
Регистрация
Восстановить пароль
Другие темы раздела
C++ Определять тип вводимой переменной (char или int) http://www.cyberforum.ru/cpp-beginners/thread1087866.html
Вообщем изначально дали задание определять тип вводимой переменной (char или int ). Это я выполнил,затем изменили задание, нужно сделать чтоб была какая-нибудь строка или символьный масив, и...
C++ Не запускается программа после компиляции здравствуйте, собственно после данного кода компилятор Dev C++ никак не реагирует после нажатия RUN, компиляция проходит успешно. Что подскажете? раньше помню когда первый раз компилировал вылезала... http://www.cyberforum.ru/cpp-beginners/thread1087861.html
C++ где ошибка в коде?
видимо неправильно работает функция симметричности матрицы. потому что ввожу не симметричную матрицу, а она все равно сдвигает строку. где ошибка? #include <iostream> using namespace std; ...
C++ Рекурсия
Вот какой самый простой пример рекурсии я обнаружил в интернете: #include <iostream> using namespace std; int factorial(int n) { if (n == 1) return 1; else return factorial(n - 1)*n; }
C++ Без дополнительных библиотек текстовый файл http://www.cyberforum.ru/cpp-beginners/thread1087822.html
Без дополнительных библиотек преобразования текстового файла / С++ для начинающих -------------------------------------------------------------------------------- Добрый день! Ребята срочно...
C++ Проложить код программы для решения школьной геометрической задачи Задача: Дано: ABCA1B1C1 – прямая треугольная призма, AB = 13, CB = 14, AC = 15, O – центр описанной окружности, C1OC = 30°. Найдите V. Код: #include <conio.h> #include <iostream> #include... подробнее

Показать сообщение отдельно
triish
1 / 1 / 0
Регистрация: 16.01.2014
Сообщений: 44

нужно сделать трассировку. кто-нибудь знает как? - C++

02.02.2014, 20:52. Просмотров 287. Ответов 1
Метки (Все метки)

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

помогите.
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
87
88
89
90
91
92
93
94
95
96
// 01(1).cpp: определяет точку входа для консольного приложения.
//
 
#include <iostream>
using namespace std;
 
const int N = 3;           //объявляем константу, выражающую количество строк и столбцов
void outM(int [N][N]);      //объявляем функцию вывода матрицы на экран
void sdvig(int [N][N]);     //объявляем функция сдвига строки с максимальным элементом
bool compareSim(int [N][N]);    //объявляем функцию, сравнивающую исходную матрицу и транспонированную
 
int main()
{
    setlocale(LC_ALL, "Russian");
 
    int z[N][N] = {{1, 2, 3},    //инициализация матрицы
                   {2, 5, 6,},    //
                   {3, 6, 9}};   //
                      //
    bool sim;          //переменная, которая скажет нам, симметрична матрица или нет
 
    cout << "исходная матрица: " << endl << endl;
    outM(z);            // вызов функции(вывод матрицы на экран)
 
    sim = compareSim(z);       //вызов ф-ции(сравнение исходной матрицы и транспонированной)
    if ( sim == 1)
        cout << "Матрица симметрична" << endl << endl;
    else
        cout << "Матрица не симметрична" << endl << endl;
 
    if (sim == 1)
    sdvig(z);     //вызов ф-ции(если матрица симметрична, сдвигает строку с максимальным значением)
 
    system("pause");
    return 0;
}
 
void outM(int z[N][N])       // обычный вывод на экран
{
    for (int i = 0; i < N; i ++)
    {
        for (int j = 0; j < N; j++)
            cout << z[i][j] << ' ';
        cout << endl << endl;
    }
}
 
 
bool compareSim(int z[N][N])            
{                                       // сравниваем каждый элемент исходной
    for (int i = 0; i < N; i++)         // матрицы c  симметричным ему элементом 
        for (int j = 0; j < N; j++)     // транспонированной матрицы
        {                               
            if (z[i][j] != z[j][i])     // возвращаем 0, если хотя бы 2 симметричных 
                return 0;               // элемента не равны
        }
    return 1;               
}
 
void sdvig(int z[N][N])             //ф-ция, сдвигающая строки с максимальным элементом
{                                   
    int temp;
    int max = z[0][0];      
    int imax[N], n = 0, M;  // объявляем массив(если будет несколько макс. значений),
    imax[0] = 0;            // где будет храниться номер строки с макс. элементом
 
    for (int i = 0; i < N; i++)         //ищем макс. элемент и 
        for (int j = 0; j < N; j++)     // запоминаем номер строки
            if (max < z[i][j])
            {
                max = z[i][j];
                imax[n] = i;
            }
 
    for (int i = 0; i < N; i++)         // перебираем все элементы 
        for (int j = 0; j < N; j++)     // и запоминаем все строки, в которых
            if (max == z[i][j])         // встречается макс. значение
                if (imax[n] != i)
                {
                    n++;
                    imax[n] = i;
                }
 
    M = n + 1;   // количество строк с макс. элементом
    for (n = 0; n < M; n++)  // сдвигаем поочередно нужные строки
    {
    temp = z[imax[n]][N - 1];  // запоминаем значение последнего элемента в строке, чтобы не потерять его
    for (int j = N - 1; j >= 0; j--)    // сам сдвиг( начинается с конца строки)
        z[imax[n]][j] = z[imax[n]][j-1];
    z[imax[n]][0] = temp;
    }
 
    cout << "конечная матрица: " << endl << endl;
    outM(z);
 
}
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
 
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru