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

С++ для начинающих

Войти
Регистрация
Восстановить пароль
 
semb
0 / 0 / 0
Регистрация: 19.12.2012
Сообщений: 9
#1

Перевод программы на С++ с Паскаля - C++

19.12.2012, 13:40. Просмотров 303. Ответов 1
Метки нет (Все метки)

Здравствуйте. Имеется следующая задача.

Для двух заданных матриц A(n,n) и B(n,n) проверить, можно ли получить вторую из первой применением конечного числа операций транспонирования относительно главной и побочной диагоналей.
Pascal
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
Uses crt;
Const row=3; col=row;
Var a: array [1..row,1..col] of  Integer;
I,j,buf: integer;
Begin
Randomize;
Writeln(‘MATRICA’);
 For i:=1 to row do
  begin
    for j:=1 to col do
      begin
       a[i,j]:=random(100);
       write(a[i,j]:4);
     end;
 writeln;
end;
{transpon}
 for i:=1 to row do
   for j:=i+1 to col do
     begin
    buf:=a[i,j]; a[i,j]:=a[j,i]; a[j,i]:=buf;
     end;
writeln(‘trans’);
 for i:=1 to row do
   begin
    for j:=1 to col do write(a[i,j]:4);
   writerln;
   end;
end.
Так - относительно побочной:
for i := 1 to row - 1 do
  for j := 1 to row - i do begin
    buf:=a[i,j]; a[i,j]:=a[row-j+1,row-i+1]; a[row-j+1,row-i+1]:=buf;
  end;
цикл, чтобы определить можно ли получить матрицу равную данной:
for i:=1 to row do
  for j:=i+1 to col do
  begin
    if a[i,j] <> a[j,i] then
    begin
      {необходимые действия в случае, если транспонированная матрица не равна исходной}
    end;
   end;
мне нужно составить задачу на С++
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
19.12.2012, 13:40     Перевод программы на С++ с Паскаля
Посмотрите здесь:

Перевод программы на С++ с Паскаля - C++
var sn,s:string; l,k,kod:integer; v,p:real; begin writeln('Введите строку'); readln(s); l:=length(s); p:=1; k:=1; ...

перевод программы из Паскаля в С++ - C++
var a,b,c:integer; begin read(a,b,c); writeln(a,'+',b,'+',c,'=',a+b+c); writeln(a,'*',b,'*',c,'=',a*b*c); ...

Перевод программы с Паскаля на C++ - C++
program LABYRINTH; {BACKTRACK1, i.e. depth-first, no infinite cycle} const M = 7; N = 7; {Dimensions} var LAB : array of integer;...

Перевод программы на С++ с Паскаля - C++
var s: string; i: byte; begin readln(s); i := 1; // избавляемся от пробелов спереди while s = ' ' do...

Перевод с Паскаля в С++ - C++
var n: longint; max,x: byte; begin write('Введите число n: '); readln(n); max:=n mod 10; while n&gt;0 do begin ...

Перевод с Паскаля на C++ - C++
Помогите пожалуйста перевести это код на C++!!!!!! Uses crt,graph; label 2,3,4; Var dr,md,i,k:integer; d:char; procedure dogd; ...

Перевод с паскаля на С++ - C++
Даны два массива A и B одинакового размера N. Сформировать новый массив C того же размера, каждый элемент которого равен максимальному из...

Перевод с паскаля на с++ - C++
program z1; var i,j,m,k,z,x,l:integer; begin readln(m); for i:=0 to m do begin z:=1; if i=0 then z:=1 else begin x:=i; ...

Перевод с Паскаля в С++ - C++
uses crt; type prm=record {прямая с полями, коэффициентами} a,b,c:real; end; tch=record {точка с полями,...

Перевод из Паскаля в Си++ - C++
program p1; var a,k:string; mas:array of string; b,c,i,nu:integer; begin nu:= 0; i:=1; readln (a); for i:=1...


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

Или воспользуйтесь поиском по форуму:
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
v.a.l.i.d
412 / 377 / 10
Регистрация: 21.09.2012
Сообщений: 913
19.12.2012, 14:13     Перевод программы на С++ с Паскаля #2
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
#include <iostream>
#include <ctime>
#include <iomanip>
using namespace std;
 
int main()
{
    const int row=3, col=row;
    int a[row][col];
    int i, j, buf;
    
    srand(time(NULL));
    
    cout << "MATRICA" << endl;
    
    for (i=0; i<row; i++)
    {
        for (j=0; j<col; j++)
        {
            a[i][j] = rand() % 100;
            cout << setw(4) << a[i][j];
        }
        cout << endl;
    }
    
    /* transpon */
    
    for (i=0; i<row; i++)
        for (j=0; j<col; j++)
        {
            buf = a[i][j];
            a[i][j] = a[j][i];
            a[j][i] = buf;
        }
        
    cout << "trans" << endl;
    for (i=0; i<row; i++)
    {
        for (j=0; j<col; j++)
            cout << setw(4) << a[i][j];
        cout << endl;
    }
    
    /* Так - относительно побочной: */
    for (i=0; i<row; i++)
        for (j=0; j<col; j++)
        {
            buf = a[i][j];
            a[i][j] = a[row-1-j][row-1-i];
            a[row-1-j][row-1-i] = buf;
        }
        
    /* цикл, чтобы определить можно ли получить матрицу равную данной: */
    for (i=0; i<row; i++)
        for (j=0; j<col; j++)
        {
            if (a[i][j] != a[j][i])
            {
                /* {необходимые действия в случае, если транспонированная матрица не равна исходной} */
            }
        }
    
    
 
 
    system("pause");
    return 0;
}
Ответ Создать тему
Опции темы

КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru