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

Проверьте листинг правильно я понял задание - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Чередование символов в строке http://www.cyberforum.ru/cpp-beginners/thread299110.html
Составить новую строку путем чередования символов обеих исходных строк. Помогите плз решить эту задачу
C++ Элементарные программы, для лучшего понимания языка... Здравствуйте. Вот сегодня решил что пора изучать с++. Есть пару задач. Начал решать и уже на первой запоролся( суть в том чтобы определить попадает ли точка в заштрихованную облась.... #include "stdafx.h" #include <stdio.h> #include <iostream> using namespace std; int _tmain(int argc, _TCHAR* argv) { int x, y; cout << ("введите координаты точки"); http://www.cyberforum.ru/cpp-beginners/thread299106.html
пересечение графов C++
Подскажите пожалуйста, что такое пересечение графов. Сколько искал ничего толкового не нашёл.
C++ Написать программу,которая вычисляет значение арифметического выражения записанного в постфиксной форме,с помощью стека
Написать программу,которая вычисляет значение арифметического выражения записанного в постфиксной форме,с помощью стека.Выражение правильное,допускаеются только однозначные числа и знаки +,-,*,/. На С++
C++ Немного подправить код http://www.cyberforum.ru/cpp-beginners/thread299094.html
здравствуйте! есть код к задаче: даны два неубывающих массива x и y. найти их "пересечение", то есть неубывающий массив z, содержащий их общие элементы, причем кратность каждого элемента в массиве z равна минимуму его кратностей в массивах x и y. вот мой код с пояснениями, вроде все по логике, но работает некорректно, кто может ,подскажите где ошибка? const int n=10,m=10; int...
C++ Визуальная среда Помогите написать программу на С++, обеспечивающую создание списка абитуриентов. Предусмотреть ввод фамилии, имени и отчества, года рождения, оценок за вступительные экзамены (математика, физика, русский язык). Программа должна позволять сохранить список в файл, загрузить его и произвести сортировку по следующим полям в порядке убывания:; фамилия, имя, отчество; год рождения, общий балл за... подробнее

Показать сообщение отдельно
.Malek.
5 / 5 / 0
Регистрация: 20.03.2011
Сообщений: 180
18.05.2011, 21:01     Проверьте листинг правильно я понял задание
Посмотрите пожалуйста я сделал задание правильно ли я понял задание с учетом требований.
Написать функцию возведения в квадрат каждого элемента матрицы (N, M), использовать ее для массива целых и вещественных чисел.

Необходимо соблюсти условия перечисленные ниже.
1. Ввод исходных данных и вывод результата на экран производить в основной программе, решение задачи осуществлять в созданной функции.
2. Не применять индексированных переменных для доступа к элементам массивов, а использовать разыменование указателей.
3. Вызывать функции через указатель на нее и обычным образом.
4. Использовать прием перегрузки функций.


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
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
#include <stdio.h>
#include <stdlib.h>
#include <iostream.h>
#include <conio.h>
#include <process.h>
#include <iomanip.h>
 
void matrixsqr(int **a, int N, int M) // Интовая версия
{ 
    //r указатель на строку
    //а-указатель на первую строку
    //*r - указатель на первый элемент строки
    //r=a+N-1 ставим указатель в самый конец у нас там N строк начиная с нулевой и до (N-1)-ой
    int *p, **r; // Указатель
    for (r=a+N-1; r>=a; --r) // Цикл со счётчиком указаетльного типа, перебираем все сктроки матрицы
    {
        for (p=*r+M-1; p>=*r; --p) // Цикл со счётчиком указаетльного типа, перебираем все элементы строки матрицы
            {
            *p=*p*(*p);
            // Возведение в квадрат умножением.
            }
    }
    return;
}
 
void matrixsqr(double **a, int N, int M) // Вещественаная версия
{ 
    double *p, **r; 
    for (r=a+N-1; r>=a; --r) // Цикл со счётчиком указаетльного типа, перебираем все сктроки матрицы
        {
            for (p=*r+M-1; p>=*r; --p) // Цикл со счётчиком указаетльного типа, перебираем все элементы строки матрицы
            {
                *p=*p*(*p); // Возведение в квадрат умножением.
            }
        }
    return;
}
 
void (*ykaz_int)( int **, int , int);
void (*ykaz_double)( double **, int , int);
 
void intova()
{
    int n, m;
    while(!(n>=1 && n<=5 && m>=1 && m<=5))
    {
        textcolor(12);
        cprintf("The maximum size of the matrix 5x5!!!");
        cout<<endl;
        cout<<"Enter n:"<<endl; cin>>n;
        cout<<"Enter m:"<<endl; cin>>m;
        cin.clear(); 
        cin.ignore(256, '\n');
    }   
        
        int** M=new int*[n];
        int i;
        for(i=0; i<n; i++)
            {
                M[i]=new int[m];
            }
                int j;
                randomize();
                cout<<endl;
                cout<<"----Before--"<<endl;
                for(i=0; i<n; i++)
                {
                    for(j=0; j<m; j++)
                        {
                            M[i][j]=random(100)-50;
                            cout<<setiosflags(ios::left)<<setw(4)<<M[i][j];
                        }
                        cout<<endl;
                }
        
                    ykaz_int=&matrixsqr;
                    (*ykaz_int)(M, n, m);
                    cout<<endl;
                    cout<<"----After--"<<endl;
                    for(i=0; i<n; i++)
                    {
                            for(j=0; j<m; j++)
                            {
                              cout<<setiosflags(ios::left)<<setw(6)<<M[i][j];
                            }
                      cout<<endl;
                    }       
                
    return;
}
 
void floytava()
{
    double n, m;
    while(!(n>=1 && n<=5 && m>=1 && m<=5))
    {
        textcolor(12);
        cprintf("The maximum size of the matrix 5x5!!!");
        cout<<endl;
        cout<<"Enter n:"<<endl; cin>>n;
        cout<<"Enter m:"<<endl; cin>>m;
        cin.clear(); 
        cin.ignore(256, '\n');
    }   
                        
        double** M=new double*[n];
        int i;
        for(i=0; i<n; i++)
            {
                M[i]=new double[m];
            }
                int j;
                randomize();
                cout<<endl;
                cout<<"----Before----"<<endl;
                for(i=0; i<n; i++)
                {
                    for(j=0; j<m; j++)
                        {
                            M[i][j]=(random(100)-50)/10.0;
                            cout<<setiosflags(ios::left)<<setw(6)<<M[i][j];
                        }
                        cout<<endl;
                }
        ykaz_double=&matrixsqr;
        (*ykaz_double)(M, n, m);
        cout<<endl;
        cout<<"----After----"<<endl;
        for(i=0; i<n; i++)
        {
                for(j=0; j<m; j++)
                {
                  cout<<setiosflags(ios::left)<<setw(8)<<M[i][j];
                }
          cout<<endl;
        }
 
    return;
}
 
 
int main()
{
       clrscr();
       int otvet;
       while(!(otvet=='1' ||otvet=='2' || otvet=='3'))
       {    
            textcolor(10);
            cprintf("Please choose the type of data int(1)or float(2). If you want to quit, press (3)");
            cin>>otvet;
               switch(otvet)
                {
                    case 1: intova();   break;
                    case 2: floytava(); break;
                    case 3: exit(0);
                };
                cin.clear(); // эта и следующая строка позволяют избежать зацикливания cin в случае ввода не числа
                cin.ignore(256, '\n');
        }
    getch();  
    return 0;
}
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 18:11. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru