Форум программистов, компьютерный форум, киберфорум
Наши страницы

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

Войти
Регистрация
Восстановить пароль
 
kaznachey1993
-66 / 3 / 0
Регистрация: 24.11.2011
Сообщений: 97
#1

Упорядочить матрицу - C++

20.06.2012, 13:44. Просмотров 304. Ответов 1
Метки нет (Все метки)

Упорядочить строки двумерной матрицы, содержащей натуральные числа с сростання количества простых чисел, встречающихся в записи цифр этих чисел.

Добавлено через 10 минут
Например матрица:
12 3 45 12 = 6,6-ето количество простых чисел
7 1 2 9 = 3,3-ето количество простых чисел
3 15 21 17=7,7-ето количество простых чисел
Вывод:
7 1 2 9
12 3 45 12
3 15 21 17
Матрица забивается рандомом!

Добавлено через 1 минуту
Пожалуйста очень надо!

Добавлено через 19 минут
Пожалуйста

Добавлено через 11 минут
Плиз.Очень надо жизненно важно!

Добавлено через 18 минут
поднятие темы
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
Similar
Эксперт
41792 / 34177 / 6122
Регистрация: 12.04.2006
Сообщений: 57,940
20.06.2012, 13:44
Здравствуйте! Я подобрал для вас темы с ответами на вопрос Упорядочить матрицу (C++):

Упорядочить матрицу - C++
Разработать программу, которая вводит целочисленную матрицу из n строк и m столбцов (1<n<=100, 1<m<=50) и упорядочить все элементы матрицы...

Упорядочить матрицу - C++
Помогите, пожалуйста : Нужно упорядочить матрицу по увеличению сумм элементов в строках. Желательно, что бы без использования функций. ...

Упорядочить матрицу по убыванию - C++
Не могу найти ошибку, что не так? Вот мой код: #include "stdafx.h" #include "iostream" using namespace std; int _tmain()...

Упорядочить матрицу(borland(cи)) - C++
Упорядочить строки матрицы m * n в порядке возрастания элементов в главной диагонали. Матрица вводится и выводится в главной программе....

Упорядочить квадратную матрицу - C++
Упорядочить (отсортировать матрицу), что бы было так: a11 <= a12 <=<= a1n <= a21 <= a22 <=<= a2n <=<= an1 <= an1 <=<= ann Плюсом...

Упорядочить матрицу по убыванию - C++
С клавиатуры вводится двумерный массив длинной 10 символов.Упорядочить массив по убыванию.

1
sandye51
программист С++
685 / 587 / 39
Регистрация: 19.12.2010
Сообщений: 2,016
20.06.2012, 13:49 #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
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
#include <cstdlib>
#include <iostream>
#include <clocale>
#include <ctime>
#include <cmath>
 
// проверка - простое число или нет
bool is_simple(int value)
{
    int n = static_cast<int>(pow(value, 0.5));
    for (int i = 2; i <= n; ++i)
        if (value % i == 0)
            return false;
    return true;
}
 
// печать матрицы вместе с простыми числами
void print_matrix(int** matrix, int* number, unsigned int size)
{
    for (unsigned int i = 0; i < size; ++i)
    {
        for (unsigned int j = 0; j < size; ++j)
            std::cout << matrix[i][j] << " ";
        std::cout << "-- " << number[i] << " простых чисел" << std::endl; 
    }
}
 
// получение массива простых чисел для матрицы
int* get_simple_numbers(int** matrix, unsigned int size)
{
    int* number = new int[size];
    
    for (unsigned int i = 0; i < size; ++i)
    {
        number[i] = 0;
        for (unsigned int j = 0 ; j < size; ++j)
            if (is_simple(matrix[i][j]))
                number[i]++;
    }
    
    return number;
}
 
// сортировка строк матрицы по количеству простых чисел в ней
void sort(int** matrix, int* numbers, unsigned int size)
{
    unsigned int iterations = 0;
    bool next = true;
    
    while (next)
    {
        next = false;
        for (unsigned int i = 0; i < size - iterations - 1; ++i)
            if (numbers[i] > numbers[i + 1])
            {
                std::swap(numbers[i], numbers[i + 1]);
                std::swap(matrix[i], matrix[i + 1]);
                next = true; 
            }
        ++iterations;
    }
}
 
int main(int argc, const char * argv[])
{
    setlocale(LC_ALL, "Russian");
    srand(static_cast<unsigned int>(time(NULL)));
    
    unsigned int size;
    
    std::cout << "Введите размер матрицы: " << std::endl;
    std::cin >> size;
    
    int** matrix = new int*[size];
    for (unsigned int i = 0; i < size; ++i)
    {
        matrix[i] = new int[size];
        for (unsigned int j = 0; j < size; ++j)
            matrix[i][j] = rand() % 100;
    }
    
    int* number = get_simple_numbers(matrix, size);
    std::cout << "До сортировки" << std::endl; 
    print_matrix(matrix, number, size);
    
    sort(matrix, number, size);
    
    std::cout << "После сортировки" << std::endl;
    print_matrix(matrix, number, size);
    
    for (unsigned int i = 0; i < size; ++i)
        delete[]matrix[i];
    delete[]matrix;
    delete[]number;
    
    system("Pause");
    return 0;
}
0
MoreAnswers
Эксперт
37091 / 29110 / 5898
Регистрация: 17.06.2006
Сообщений: 43,301
20.06.2012, 13:49
Привет! Вот еще темы с ответами:

Упорядочить матрицу быстрой сортировкой - C++
Есть прога, которая сортирует матрицу по возрастанию отрицательных значений различными методами сортировки, а также выводит на экран...

Упорядочить квадратную матрицу в соответствии с условием - C++
Добрый день. дана входная строка из нескольких цифр: 1 2 3 4 Необходимо отсортировать новую квадратную матрицу что бы получилось так как на...

Построить симметричную матрицу и упорядочить ее по возрастанию - C++
заданы два целых массивы чисел A(n), n&lt;=300 B(m), m&lt;=300. Разработать программу, которая строит симметричную разницу A\B\bigcupB\A и...

Упорядочить матрицу по возрастанию наибольших элементов в строках - C++
Дана вещественная матрица размером NxM. Упорядочить ее строки по возрастанию наибольших элементов в строках матрицы. Помогите...


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

Или воспользуйтесь поиском по форуму:
2
Ответ Создать тему
Опции темы

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