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

Перевести из C++ на С. - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Динамический массив целых чисел http://www.cyberforum.ru/cpp-beginners/thread416986.html
Здравствуйте! Помогите создать динамический массив целых чисел. Заполнить с клавиатуры. Количество элементов задается случайно. Найти сумму модулей элементов массива, расположенных после первого элемента, равного нулю. При написании использовать функцию
C++ Странная ошибка при удалении из базы. Здравствуйте. Есть код готовый, рабочий с баззой данных. Ошибка вылетает(через раз) когда сначала добавляется элемент а потом удаляется(дугой). Помогите пожалуйста исправить! Может это только у меня ошибку выдает. #include "stdafx.h" #include <iostream> using namespace std; class student { http://www.cyberforum.ru/cpp-beginners/thread416975.html
C++ Динамический массив целых чисел
Здравствуйте! Помогите создать динамический массив целых чисел. Заполнить с клавиатуры. Количество элементов задается случайно. Найти сумму модулей элементов массива, расположенных после первого элемента, равного нулю. При написании использовать функцию
C++ Перегрузка оператора сдвига
Мне нужно перегрузить операторы>>, <<как члены класса, написал так: istream& Flower::operator>>(Flower& obj) { this >> obj.title; return *this; }
C++ Переставить слова заданного предложения в соответствии с ростом согласных в этих словах. http://www.cyberforum.ru/cpp-beginners/thread416962.html
Добрый день. В универе дали задачку "Переставить слова заданного предложения в соответствии с ростом согласных в этих словах." Ломал голову 2 недели, но ничего путного не придумал. Запрогать надо на VC++. Буду рад, если кто-нибудь подаст идеи. Вот мой бред, но это я даже до самой сортировки слов не дошел. #include "stdafx.h" #include <iostream> #include <windows.h> //Перевод на русский...
C++ Программа считывает двузначное число и выводит через пробел каждую цифру отдельно Программа считывает двузначное число и выводит через пробел каждую цифру отдельно. подробнее

Показать сообщение отдельно
igor0802
0 / 0 / 0
Регистрация: 22.12.2011
Сообщений: 26
25.12.2011, 14:32     Перевести из C++ на С.
нужно код перевести в С!

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
#include <iostream.h>
#include <fstream.h>
 
main(int argc, char *argv[]) {
    //definition of the variables.
    int mtx1[20][20], mtx2[20][20], mtx3[20][20], mtx4[20][20];
    int n, i, j, k;
    int nlink=2, max=9999;
 
    //exit if the number of arguments is not 1.
    if(argc != 2) {
        cerr << "Usage: shimbel <filename>\n";
        return 1;
    }
 
    //open the input file. exit if an error occurs.
    ifstream fin(argv[1]);
    if(!fin) {
        cerr << "Can't open file!\n";
        return 1;
    }
 
    //read the input file.
    fin >> n;           //read the number of rows and columns.
    for(j=1; j<=n; j++) {
        for(i=1; i<=n; i++) {
            fin >> mtx1[i][j];  //read the elements of the matrix.
        }
    }
    fin.close();                //close the file.
 
    for(j=1; j<=n; j++) {
        for(i=1; i<=n; i++) {
            mtx2[i][j] = mtx1[i][j];    //copy elements of mtx1 into mtx2.
        }
    }
 
    for(j=1; j<=n; j++) {
        for(i=1; i<=n; i++) {
            mtx4[i][j] = 9999;      //set elements of mtx4 as 9999.
        }
    }
 
    for(j=1; j<=n; j++) {
        for(i=1; i<=n; i++) {
            if(i == j) {
                mtx4[i][j] = 0; //put 0 in the diagonal elements.
            } else if(mtx1[i][j] == 1) {
                mtx4[i][j] = 1; //put 1 if a linkage exists between the nodal pair.
            }
        }
    }
 
    nlink = 2;      //start with 2 step path.
    while(1) {      //endless loop
        for(j=1; j<=n; j++) {
            for(i=1; i<=n; i++) {
                mtx3[i][j] = 0; //set elements of mtx3 as 0.
            }
        }
 
        for(j=1; j<=n; j++) {
            for(i=1; i<=n; i++) {
                for(k=1; k<=n; k++) {
                    mtx3[i][j] += mtx2[i][k] * mtx1[k][j];  //multiply the matrices.
                }
                if (mtx3[i][j] != 0){
                    if(mtx4[i][j] > nlink) {
                        mtx4[i][j] = nlink; //put the step number in the nodal pair when it becomes non-zero firstly.
                    }
                }
            }
        }
 
        //get the maximum element of mtx4.
        max = 0;
        for(j=1; j<=n; j++) {
            for(i=1; i<=n; i++) {
                if(mtx4[i][j] > max) {
                    max = mtx4[i][j];
                }
            }
        }
        if(max < 9999) break;   //if the maximun is not 9999, exit the loop.
 
        for(j=1; j<=n; j++) {
            for(i=1; i<=n; i++) {
                mtx2[i][j] = mtx3[i][j];    //copy elements of mtx3 into mtx2.
            }
        }
 
        nlink++;                //increment nlink.
    }                           //end of the loop.
 
    //output the results.
    cout << n << "\n";          //number of rows and columuns
    for(j=1; j<=n; j++) {
        for(i=1; i<=n; i++) {
            cout << mtx4[i][j]; //elements of the matrix
            if(i < n) {
                cout << "\t";
            }
        }
    cout << "\n";
    }
 
    return 0;
}   //end of the program.
После регистрации реклама в сообщениях будет скрыта и будут доступны все возможности форума.
 
Текущее время: 23:01. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2016, vBulletin Solutions, Inc.
Рейтинг@Mail.ru