Форум программистов, компьютерный форум, киберфорум
C для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.50/4: Рейтинг темы: голосов - 4, средняя оценка - 4.50
1 / 1 / 0
Регистрация: 24.02.2021
Сообщений: 63

Перевод с C++ в си

29.04.2021, 09:26. Показов 879. Ответов 2

Студворк — интернет-сервис помощи студентам
Здравствуйте пом0гите перевести с С++ в си
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
#include <iostream>
#include <iomanip>
 
int main()
{
    int n;
    std::cin >> n;
    float** arr = new float* [n];
    float max;
    int i_max, j_max;
    for (int i = 0; i < n; ++i)
    {
        arr[i] = new float [n];
        for (int j = 0; j < n; ++j)
        {
            std::cin >> arr[i][j];
            if (((!i) && (!j)) || (arr[i][j] > max))
            {
                max = arr[i][j];
                i_max = i;
                j_max = j;
            }
        }
    }
    arr[i_max][j_max] = arr[0][0]; 
    arr[0][0] = max;
    for (int count = 1; count < n; ++count)
    {
        max = arr[0][1];
        for (int i = 0; i < n; ++i)
            for (int j = 0; j < n; ++j)
                if (((i != j) || ((i >= count) && (j >= count))) && (arr[i][j] > max))
                {
                    max = arr[i][j];
                    i_max = i;
                    j_max = j;
                }
        arr[i_max][j_max] = arr[count][count]; 
        arr[count][count] = max;
    }
    for (int i = 0; i < n; ++i)
    {
            for (int j = 0; j < n; ++j)
                std::cout << std::setw(5) << arr[i][j];
            std::cout << std::endl;
    }
    for (int i = 0; i < n; ++i)
    {
        int count = 0;
            for (int j = 0; j < n; ++j)
                if (arr[i][j] < 0)
                    ++count;
            if (count == n)
            {
                std::cout << "line #" << i + 1 << " has no positive numbers\n";
                system("pause");
                return 0;
            }
    }
    std::cout << "all lines have positive numbers\n";
    system("pause");
    return 0;
}
0
IT_Exp
Эксперт
34794 / 4073 / 2104
Регистрация: 17.06.2006
Сообщений: 32,602
Блог
29.04.2021, 09:26
Ответы с готовыми решениями:

Перевод символов в число(машинный код), сложение с другим числом,обратный перевод в символ
Проблема такова: на вход поступает текст(на русском языке), по символьно надо перевести каждую букву в число, в зависимости от способа...

Перевод кода с Паскаля в Си. (Перевод цепной дроби в обыкновенную)
Помогите переписать на Си, пожалуйста. procedure AntiExp; var s: array of integer; a,b, i,n,t: integer; q: char; begin ...

Перевод кода с Паскаля (перевод в метры)
var a,b,d:integer; c,e:real; begin writeln('1-дециметр 2-километр'); writeln('3-метр 4-миллиметр'); ...

2
Модератор
Эксперт CЭксперт С++
 Аватар для Volga_
5208 / 2925 / 1509
Регистрация: 14.12.2018
Сообщений: 5,266
Записей в блоге: 1
29.04.2021, 09:45
Цитата Сообщение от Erkosha132 Посмотреть сообщение
перевести с С++ в си
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
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
 
int main()
{
    int n;
    scanf("%d", &n);
    float** arr = (float**)malloc(n * sizeof(float*));
    float max;
    int i, j;
    int i_max, j_max;
    for (i = 0; i < n; ++i)
    {
        arr[i] = (float*)malloc(n * sizeof(float));
        for (j = 0; j < n; ++j)
        {
            printf("%f", arr[i][j]);
            if (((!i) && (!j)) || (arr[i][j] > max))
            {
                max = arr[i][j];
                i_max = i;
                j_max = j;
            }
        }
    }
    arr[i_max][j_max] = arr[0][0];
    arr[0][0] = max;
    int count;
    for (count = 1; count < n; ++count)
    {
        max = arr[0][1];
        for (i = 0; i < n; ++i)
            for (j = 0; j < n; ++j)
                if (((i != j) || ((i >= count) && (j >= count))) && (arr[i][j] > max))
                {
                    max = arr[i][j];
                    i_max = i;
                    j_max = j;
                }
        arr[i_max][j_max] = arr[count][count];
        arr[count][count] = max;
    }
    for (i = 0; i < n; ++i)
    {
        for (j = 0; j < n; ++j)
            printf("%5f", arr[i][j]);
        printf("\n");
    }
    for (i = 0; i < n; ++i)
    {
        count = 0;
        for (j = 0; j < n; ++j)
            if (arr[i][j] < 0)
                ++count;
        if (count == n)
        {
            printf("line #%d has no positive numbers\n", i + 1);
            getch();
            return 0;
        }
    }
    printf("all lines have positive numbers\n");
    getch();
    return 0;
}
1
2487 / 1151 / 709
Регистрация: 25.04.2016
Сообщений: 3,315
29.04.2021, 16:09
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
#include <stdio.h>
#include <stdlib.h>
#define swap_float(a, b) {float temp = a; a = b; b = temp;}
 
float ** create_2d (int, int);
void free_2d (float **);
int input_2d (float **, int, int);
div_t maximum (float **, int, int, int);
void print_2d (float **, int, int);
 
int main (void) {
    int i, k, n;    // размер массива
    if (scanf("%d", &n) != 1 || n < 1) {
        fputs("Input Error!\n", stderr);
        return 1;
    }
 
    // запрашиваем память под массив
    float ** a = create_2d(n, n);
    if (a == NULL) {
        fputs("Error allocate memory!\n", stderr);
        return 2;
    }
 
    // заполняем массив значениями с клавиатуры
    if (input_2d(a, n, n) == 1) {
        fputs("Input Error!\n", stderr);
        free_2d(a);
        return 1;
    }
 
    print_2d(a, n, n);      // массив до преобразований
 
    for (i = 0; i < n; i++) {
        div_t max = maximum(a, n, n, i);
        swap_float(a[max.quot][max.rem], a[i][i]);
    }
 
    print_2d(a, n, n);      // массив после всех преобразований
 
    // проверяем на положительные
    int cnt, check = 0;
    for (i = 0; i < n && !check; ++i) {
        for (k = cnt = 0; k < n; ++k)
            cnt += (a[i][k] < 0);
        check = (cnt == n)? i+1 : 0;
    }
    if (check)
        printf("line #%d hasn't positive numbers\n", check);
    else
        puts("all lines have positive numbers");
 
    // system("pause");
    free_2d(a);             // освобождаем память, занятую массивом
    return 0;               // и выходим
}
// -------------------------------------------------------------
float ** create_2d (int rows, int columns) {
    float  ** a = (float **) malloc(sizeof(float *) * rows);
    if (a == NULL)
        return NULL;
    a[0] = (float *) malloc(sizeof(float) * rows*columns);
    if (a[0] == NULL) {
        free(a);
        return NULL;
    }
    for (int i=1; i<rows; i++)
        a[i] = a[i-1] + columns;
    return a;
}
// -------------------------------------------------------------
void free_2d (float ** array) {
    free(array[0]);
    free(array);
}
// -------------------------------------------------------------
int input_2d (float ** array, int rows, int columns) {
    for (int i = 0; i < rows; ++i)
        for (int k = 0; k < columns; ++k)
            if (scanf("%f", &array[i][k]) != 1)
                return 1;
    return 0;
}
// -------------------------------------------------------------
div_t maximum (float ** array, int rows, int columns, int count) {
    div_t max;
    int first = 1;
    for (int i = 0; i < rows; ++i)
        for (int k = 0; k < columns; ++k) {
            if (i == k && i < count)
                continue;
            if (first > 0 || array[i][k] > array[max.quot][max.rem])
                first = 0,
                max.rem = k,
                max.quot = i;
        }
    return max;
}
// -------------------------------------------------------------
void print_2d (float ** array, int rows, int columns) {
    for (int i = 0; i < rows; ++i, puts(""))
        for (int k = 0; k < columns; ++k)
            printf("% 6.2f", array[i][k]);
    puts("");
}
// -------------------------------------------------------------
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
BasicMan
Эксперт
29316 / 5623 / 2384
Регистрация: 17.02.2009
Сообщений: 30,364
Блог
29.04.2021, 16:09
Помогаю со студенческими работами здесь

Создать файл, который содержит английские слова и их перевод. Обеспечить перевод английского слова
Здравствуйте. Помогите пожалуйста реализовать программу с таким условием: Создать файл, который содержит английские слова и их...

Заменить в строке все пробелы на перевод строки, а перевод строки изменить на два перевода
Меня интересует следующий вопрос: как заменить в моем стринге все пробелы на переходы на новую строку, а переходы на новую строку изменить...

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

Разбиение строки на части, перевод строки в число и перевод числа
Есть задание: 1. Необходимо реализовать консольное приложение, позволяющее манипулировать строкой, разбив ее на элементы путем...

Перевод с C++ на C#
Всем привет!) Помогите перевести код в приложенном проекте.


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
Новые блоги и статьи
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США.
Programma_Boinc 26.12.2025
Кто-нибудь знает, где можно бесплатно получить настольный компьютер или ноутбук? США. Нашел на реддите интересную статью под названием «Кто-нибудь знает, где получить бесплатный компьютер или. . .
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/ нашёл схожую тему. Там приведён код на С++, который показывает только имена СОМ портов, типа,. . .
Сколько Государство потратило денег на меня, обеспечивая инсулином.
Programma_Boinc 20.11.2025
Сколько Государство потратило денег на меня, обеспечивая инсулином. Вот решила сделать интересный приблизительный подсчет, сколько государство потратило на меня денег на покупку инсулинов. . . .
Ломающие изменения в C#.NStar Alpha
Etyuhibosecyu 20.11.2025
Уже можно не только тестировать, но и пользоваться C#. NStar - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru