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

Описать процедуру ArrayToMatrRow - C++

Восстановить пароль Регистрация
Другие темы раздела
C++ Обьясните пожалуйста http://www.cyberforum.ru/cpp-beginners/thread621628.html
struct Test { void test(); }; int main() { Test *ptr = NULL; ptr->test(); }
C++ Нули после числа Как сделать так, чтобы когда число выводилось, то после него всегда было ".00"? Напишите, пожалуйста, пример в коде. http://www.cyberforum.ru/cpp-beginners/thread621621.html
C++ Выведите YES, если число N является точной степенью двойки, или NO в противном случае.(Рекурсия)
Дано натуральное число N. Выведите слово YES, если число N является точной степенью двойки, или слово NO в противном случае.(Рекурсия) Операцией возведения в степень пользоваться нельзя! ввод - 8 вывод - YES ввод - 3 вывод - NO Правильно ли мое решение? Есть ли другие решения?
Как перевести каретку в определенное место? C++
Мне надо поставить каретку в определенное место, но не знаю как... Напишите, пожалуйста, как это сделать и пример кода.
C++ Сортировать массивы по возрастанию и по убыванию http://www.cyberforum.ru/cpp-beginners/thread621593.html
Дано одномерный массив, состоящий из 20и элементов. Сортировать эти массивы по возрастанию и по убыванию. Примеры в Турбо с++. или можете мой пример изменить. я так и не смог. #include <iostream.h> #include <math.h> int main() { int a, n, i, j; cin >> n; for(i=0; i<n; i++) cin >> a;
C++ Знаю ли я основы ООП? ООП я изучал но не применял, ну если не считать собственный класс string и примитивную обертку WinAPI. Так что прошу дайте мне задачи по ООП, чтобы понять на каком уровне находятся мои знания, и на основе этих результатов понять могу ли я читать книгу четырех или еще рано. подробнее

Показать сообщение отдельно
Кот Ангенс
 Аватар для Кот Ангенс
317 / 267 / 37
Регистрация: 24.05.2012
Сообщений: 629
10.07.2012, 10:58     Описать процедуру ArrayToMatrRow
Оптимальный метод:
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
#include <memory.h>
#include <stdio.h>
#include <stdlib.h>
 
typedef float real;
 
real* ArrayToMatrRow(const real a[ ], unsigned k, unsigned m, unsigned n, real* b) {
    m *= n;
    b = (real*)malloc(m * sizeof(real));
    if (m > k) {
        memset(b + k * sizeof(real), 0x00, (m - k) * sizeof(real));
        m = k;
    }
    while (m--)
        b[m] = a[m];
    return b;
}
 
int main() {
    real* a;
    unsigned i, k, m, n;
    real* b;
    scanf("%u", &k);
    a = (real*)malloc(k * sizeof(real));
    for (i = 0; i < k; i++)
        scanf("%f", &a[i]);
    ArrayToMatrRow(a, k, m, n, b);
    free(a);
    i = 0;
    m *= n;
    do {
        printf("%5f", b[i++]);
        if (!(i % n))
            putchar('\n');
    } while (i < m);
    free(b);
}
Понятный метод:
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
#include <stdio.h>
#include <stdlib.h>
 
typedef float real;
 
real** ArrayToMatrRow(const real a[ ], unsigned k, unsigned m, unsigned n, real** b) {
    unsigned i, j, l;
    b = (real**)malloc(m * sizeof(real*));
    for (i = 0; i < m; i++) {
        b[i] = (real*)calloc(n * sizeof(real));
        if ((l = i * n) < k)
            for (j = 0; j < n && j < l; j++)
                b[i][j] = a[l + j];
    }
    return b;
}
 
int main() {
    real* a;
    unsigned i, k, m, n;
    real** b;
    scanf("%u", &k);
    a = (real*)malloc(k * sizeof(real));
    for (i = 0; i < k; i++)
        scanf("%f", &a[i]);
    ArrayToMatrRow(a, k, m, n, b);
    free(a);
    for (i = 0; i < m; i++) {
        for (j = 0; j < n; j++)
            printf("%5f", b[i][j]);
        free(b[i]);
        putchar('\n');
    }
    free(b);
}
 
Текущее время: 11:50. Часовой пояс GMT +3.
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin® Version 3.8.9
Copyright ©2000 - 2017, vBulletin Solutions, Inc.
Рейтинг@Mail.ru