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

Вывести элементы, присутствующие в обоих массивах А и В. Алгоритм сортировки - подсчетом, алгоритм поиска - двоичный

22.10.2018, 12:32. Показов 2183. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Вывести элементы, присутствующие в обоих массивах А и В. Алгоритм сортировки - подсчетом, алгоритм поиска - двоичный.
Помогите пожалуйста составить программу, заранее спасибо!
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
22.10.2018, 12:32
Ответы с готовыми решениями:

Вывести элементы, присутствующие в обоих массивах А и В
Помогите пожалуйста! Вывести элементы, присутствующие в обоих массивах А и В. Алгоритм сортировки - вставками, алгоритм поиска -...

Найти элементы присутствующие в обоих массивах
Спокойно скомпилировала, но вылетает при запуске. Где кроется ошибка? #include <iostream> #include <stdio.h> #include...

Нужно найти элементы, присутствующие в обоих массивах А и В
Нужно найти элементы, присутствующие в обоих массивах А и В, массивы задать рандомными числами. по 10 элементов.

4
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
22.10.2018, 13:04
Если без заумных словей и попроще, то так:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
using System;
using System.Linq;
 
namespace Question2338238
{
    class Program
    {
        static void Main(string[] args)
        {
            var array1 = new int[] { 3, 7, 5, 4, 1, 9, 1, 8 };
            var array2 = new int[] { 5, 3, 2, 0 };
            var array3 = array1.SelectMany(e1 => array2.Where(e2 => e2 == e1));
 
            // Вывод
            foreach (var item in array3)
            {
                Console.WriteLine(item);
            }
            Console.ReadKey();
        }
    }
}
Алгоритм сортировки - подсчетом, алгоритм поиска - двоичный. - должны быть в конспектах лекций в Вашей тетради ))
0
1 / 1 / 0
Регистрация: 20.10.2018
Сообщений: 51
22.10.2018, 13:16  [ТС]
Увы, нету такого в тетрадях, не объясняют. А как будет выглядеть заумно? Очень интересно)
0
Эксперт JS
6496 / 3907 / 2006
Регистрация: 14.06.2018
Сообщений: 6,781
23.10.2018, 11:10
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
using System;
 
namespace Question2338233
{
    class Program
    {
        static void Main(string[] args)
        {
            var array1 = new int[] { 3, 7, 5, 4, 1, 9, 1, 8 };
            var array2 = new int[] { 5, 3, 2, 0 };
 
            //var array3 = array1.SelectMany(e1 => array2.Where(e2 => e2 == e1));
            //// Вывод
            //foreach (var item in array3)
            //{
            //    Console.WriteLine(item);
            //}
 
            CountingSort(array1);
            foreach (var item in array2)
            {
                if(Contains(array1,item))
                    Console.WriteLine(item);
            }
 
            Console.ReadKey();
        }
 
        /// <summary>
        /// Бинарный поиск элемента в сортированном массиве.
        /// Если массив не отсортирован, то метод может выдать неверный результат.
        /// </summary>
        /// <param name="array">Сортированный массив целых чисел, в котором ведется поиск.</param>
        /// <param name="element">Элемент, который нужно найти. В данном случае целое число.</param>
        /// <returns></returns>
        public static bool Contains(int[] array, int element)
        {
            int l = 0, r, i, dif;
            if (array == null || (r = array.Length - 1) == -1)
                return false;
 
            while (l <= r)
            {
                i = l + (r - l) / 2;
                dif = array[i] - element;
                if (dif == 0)
                    return true;
                if (dif < 0)
                    l = i + 1;
                else if (dif > 0)
                    r = i - 1;
            }
            return false;
        }
 
        /// <summary>
        /// Сортировка подсчетом. Простейший алгоритм.
        /// https://ru.wikipedia.org/wiki/Сортировка_подсчётом
        /// </summary>
        /// <param name="array">Массив целых чисел, который необходимо отсортировать.</param>
        public static void CountingSort(int[] array, int k = 10)
        {
            // входной массив состоит из n целых чисел
            var n = array.Length;
            // Создать вспомогательный массив C[0..k - 1], состоящий из нулей.
            var c = new int[k];
            // затем последовательно прочитать элементы входного массива A, для каждого A[i] увеличить C[A[i]] на единицу.
            for (int i = 0; i < n; ++i)
            {
                ++c[array[i]];
            }
            //  Теперь достаточно пройти по массиву C, и последовательно раскладывать в исходный массив индексы из С с учетом их ненулевого количества.
            var b = 0;
            for (int i = 0; i < k; ++i)
                for (int j = 0; j < c[i]; ++j)
                {
                    array[b++] = i;
                }
        }
    }
}
Оба алгоритма запишите себе. Пригодится в общении с преподавателем.

Кстати, оба алгоритма имеют огромное количество критических недостатков и в целом существенно хуже в применении, чем array.SelectMany().
0
1 / 1 / 0
Регистрация: 20.10.2018
Сообщений: 51
23.10.2018, 12:00  [ТС]
Хорошо, спасибо!)
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
23.10.2018, 12:00
Помогаю со студенческими работами здесь

Отсортировать два одномерных массива пузырьком и найти элементы, присутствующие в обоих массивах
Доброго времени суток. И так задача такова: отсортировать два одномерных массива (пузырьком) и найти элементы присутствующие в обоих...

Создайте одномерный массив C(mass3), который содержит элементы,присутствующие в обоих массивах A(mass) и B(mass2)
Создайте одномерный массив C(mass3), который содержит элементы,присутствующие в обоих массивах A(mass) и B(mass2).Помогите пожалуйста. ...

Алгоритм сортировки подсчетом
Здравствуйте, помогите пожалуйста написать, алгоритм сортировки подсчетом на PHP.

Квадратичный алгоритм сортировки подсчётом
Здравствуйте!я сижу туплю.....немного понимаю в циклах for в массиве...помогите пожалуйста..как реализовать эту пытался начать:Что мне...

Алгоритм сортировки записей подсчетом
Я не очень понимаю, вообще типовой алгоритм сортировки подсчетом для массива целых (даже натуральных) чисел в лиапазоне 0 - K Пусть...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
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 - писать оконные приложения, содержащие надписи, кнопки, текстовые поля и даже изображения, например, моя игра "Три в ряд" написана на этом. . .
Мысли в слух
kumehtar 18.11.2025
Кстати, совсем недавно имел разговор на тему медитаций с людьми. И обнаружил, что они вообще не понимают что такое медитация и зачем она нужна. Самые базовые вещи. Для них это - когда просто люди. . .
Создание Single Page Application на фреймах
krapotkin 16.11.2025
Статья исключительно для начинающих. Подходы оригинальностью не блещут. В век Веб все очень привыкли к дизайну Single-Page-Application . Быстренько разберем подход "на фреймах". Мы делаем одну. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2025, CyberForum.ru