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

Задача на С

11.12.2018, 17:17. Показов 449. Ответов 2
Метки нет (Все метки)

Author24 — интернет-сервис помощи студентам
Есть код на с++, помогите переделать на С.
Найти максимальный элемент и поменять его с последним элементом.
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
#pragma hdrstop
#include <iostream>
#include <conio.h>
 
using namespace std;
//---------------------------------------------------------------------------
 
#pragma argsused
 
void Fun(int **matrix, size_t rowsCount, size_t colsCount)
{
    int* maximal(*matrix);
    for (size_t i = 0; i < rowsCount; i++) {
        for (size_t j = 0; j < colsCount; j++) {
            maximal = *maximal < matrix[i][j] ? &matrix[i][j] : maximal;
        }
    }
    int temp(*maximal);
    *maximal = matrix[rowsCount - 1][colsCount - 1];
    matrix[rowsCount - 1][colsCount - 1] = temp;
}
int main(int argc, char* argv[])
{
   int **a,i,j,n,m,rez;
   cout << "Input n,m:\n ";
   cin >> n >> m;
   a = new int*[n];
   for(i=0; i<n;i++)
        a[i] = new int[m];
    cout <<"\n Input A" << endl;
    for(i=0; i<n; i++)
        for(j=0; j<m; j++){
            cout << "\t a[" << i+1 << "][" << j+1 << "] = ";
            cin >> a[i][j];
        }
    cout <<"\n Matrix A:" << endl;
    for(i=0; i<n; i++) {
        for(j=0; j<m; j++)
            cout << "\t" << a[i][j];
            cout << endl;
    }
    Fun(a,n,m);
    cout <<"\n Matrix Izmen:" << endl;
    for(i=0; i<n; i++) {
        for(j=0; j<m; j++)
            cout << "\t" << a[i][j];
        cout << endl;
    }
    delete []a;
    cout << "\n\t Delete !" << endl;
   getch();
}
0
Programming
Эксперт
94731 / 64177 / 26122
Регистрация: 12.04.2006
Сообщений: 116,782
11.12.2018, 17:17
Ответы с готовыми решениями:

Задача: В некотором государстве ввели компьютерный паспорт гражданина.(задача)
Доброго времени суток,форумчане. Хотелось бы попросить помощи в решении одной задачи от умных...

Задача на перебор вариантов. Задача Л.Эйлера. Про чиновника
Задача Л.Эйлера. Некий чиновник купил лошадей и быков на сумму 1770 талеров. За каждую лошадь он...

Задача на k-тую цифру последовательности, задача на схему Горнера.
Ну, собственно опять прошу помощи... Задача 1: Определить k-тую цифру последовательности...

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

2
112 / 91 / 31
Регистрация: 24.10.2018
Сообщений: 336
11.12.2018, 17:28 2
Для выделения памяти используем malloc, для освобождения - free, для ввода scanf, для вывода - printf. В целом все, вперед. Что не получится - пиши.
0
0 / 0 / 0
Регистрация: 15.11.2018
Сообщений: 9
13.12.2018, 17:30  [ТС] 3
Выдаёт ошибку на этой строчке, которую пометил красным, помоги исправить.
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
//---------------------------------------------------------------------------
 
#pragma hdrstop
#include <stdio.h>
#include <conio.h>
#include <stdlib.h>
 
//---------------------------------------------------------------------------
 
#pragma argsused
void Fun(double **matrix, size_t rowsCount, size_t colsCount)
{
    double* maximal(*matrix);
    for (size_t i = 0; i < rowsCount; i++) {
        for (size_t j = 0; j < colsCount; j++) {
            maximal = *maximal < matrix[i][j] ? &matrix[i][j] : maximal;
        }
    }
    int temp(*maximal);
    *maximal = matrix[rowsCount - 1][colsCount - 1];
    matrix[rowsCount - 1][colsCount - 1] = temp;
}
int main(int argc, char* argv[])
{   double **a,n,m,rez;
    int i,j;
    puts("Input n,m:");
    scanf("%fl%fl",&n,&m);
    a = (double**) malloc (n*sizeof(double*));
    for (i=0; i<n; i++)
[COLOR="Red"]    a[i] = (double*) malloc (m*sizeof(double));[/COLOR]
    puts("\n Input A");
     for(i=0; i<n; i++)
        for(j=0; j<m; j++){
        printf("\t a[i+1] %7.3lf \n [j+1] %7.3lf\n  = ", a[i][j]);
        }
    puts("\n Matrix A");
     for(i=0; i<n; i++) {
        for(j=0; j<m; j++)
            printf("\t ", a[i][j]);
    }
    Fun(a,n,m);
    puts("\n Matrix Izmen:");
    for(i=0; i<n; i++) {
        for(j=0; j<m; j++)
            printf("\t ", a[i][j]);;
    }
    free (a[i]);
    puts ("\n\t Delete !");
    getch();
}
//---------------------------------------------------------------------------
0
13.12.2018, 17:30
IT_Exp
Эксперт
87844 / 49110 / 22898
Регистрация: 17.06.2006
Сообщений: 92,604
13.12.2018, 17:30
Помогаю со студенческими работами здесь

Задача о размещении весов по ящикам (задача о рюкзаках)
Есть упорядоченный по невозрастанию набор весов предметов w1..wn, которые необходимо распределить...

Задача линейного программирования, транспортная задача
Всем привет. сижу на экзамене, помогите пожалуйста решить,сроно!!! заранее спасибо.

Задача о размене -задача динамического программирования?
Является ли задача о размене суммы задачей динамического программирования? Мне кажется нет. хотя...

Задача на файл и задача на создание очереди
1 Дан символьный файл, содержащий, по крайней мере, один символ пробела. Удалить из файла все...


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

Или воспользуйтесь поиском по форуму:
3
Ответ Создать тему
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2024, CyberForum.ru