Главная страница
Навигация по странице:

  • Краткие теоретические сведения

  • HashSet и SortedSet

  • Операции над множествами

  • Разность множеств С помощью метода Except

  • Пересечение множеств

  • Объединение множеств Для объединения двух множеств используется метод Union

  • Практическая часть Задание 1.

  • Контрольные вопросы

  • практическая работа. Практическая работа 17 Тема работы Работа с данными типа множество.


    Скачать 35.53 Kb.
    НазваниеПрактическая работа 17 Тема работы Работа с данными типа множество.
    Анкорпрактическая работа
    Дата27.02.2023
    Размер35.53 Kb.
    Формат файлаdocx
    Имя файла17.docx
    ТипПрактическая работа
    #958139

    Практическая работа №17

    Тема работы:«Работа с данными типа множество.»

    Цель работы: получение практических навыков работы с правилами объявления и использования переменных типа множество на языке программирования С#; а также с операциями и процедурами при работе с ними.

    Краткие теоретические сведения

    Множество (Set) - это совокупность однотипных объектов, рассматриваемая как одно целое. Коллекция, содержащая только отличающиеся элементы, называетсямножеством.Для работы с множествами в библиотеке классов .NET Framework имеется целых два обобщённых класса HashSet и SortedSet, которые находятся в пространстве имён System.Collections.Generic. Различие между ними в том, что SortedSet представляет упорядоченное множество.

    Операции над множествами



    Add - добавление элемента. Если такой элемент уже присутствует, то он не будет добавлен.

    Remove - удаление элемента из множества.

    Union - объединение множеств. Создается новое множество, включающее в себя все элементы из множества А и множества В. Если элемент содержится в обоих множествах, он будет добавлен однократно.

    Разность множеств

    С помощью метода Except можно получить разность двух множеств:

    string[] soft = { "Microsoft", "Google", "Apple"};

    string[] hard = { "Apple", "IBM", "Samsung"};

     // разность множеств

    var result = soft.Except(hard);

     

    foreach (string s in result)

        Console.WriteLine(s);

    В данном случае из массива soft убираются все элементы, которые есть в массиве hard. Результатом операции будут два элемента:

    • Microsoft

    • Google

    Пересечение множеств

    Для получения пересечения множеств, то есть общих для обоих наборов элементов, применяется метод:

    string[] soft = { "Microsoft", "Google", "Apple"};

    string[] hard = { "Apple", "IBM", "Samsung"};

     // пересечение множеств

    var result = soft.Intersect(hard);

     foreach (string s in result)

        Console.WriteLine(s);

    Так как оба набора имеют только один общий элемент, то соответственно только он и попадет в результирующую выборку:

    • Apple

    Объединение множеств

    Для объединения двух множеств используется метод Union. Его результатом является новый набор, в котором имеются элементы, как из одного, так и из второго множества. Повторяющиеся элементы добавляются в результат только один раз:

    string[] soft = { "Microsoft", "Google", "Apple"};

    string[] hard = { "Apple", "IBM", "Samsung"};

     

    // объединение множеств

    var result = soft.Union(hard);

     

    foreach (string s in result)

      Console.WriteLine(s);

    Практическая часть

    Задание 1.

    1. Сформировать множество, содержащее 5 целых чисел из диапазона 1..10 и вывести это множество на экран.

    2. Дана строка. Содержит ли она только латинские символы?

    3. Дана строка. Содержит ли она и строчные символы?

    4. Дана строка. Содержит ли она только русские символы?

    5. Дана строка. Содержит ли она и прописные символы?

    6. Дана строка. Содержит ли она только арабские цифры?

    7. Даны 2 строки. Входят ли все символы одной строки в другую?

    8. Дана строка. Содержит ли она символы “№ ! » ; , . % : ? @ # $ ^ & * ( )” ?

    9. Разработать программу, какому алфавиту (русскому или латинскому), принадлежит введенный с клавиатуры символ.

    10. Даны два множества, состоящие из 10 целых чисел из диапазона 1..100. Из них выделить одно подмножество, делящееся на 2 без остатка, и другое, делящееся на 3 без остатка.

    11. Дана строка символов. Требуется построить и вывести множество, элементами которого являются гласные буквы, которые входят в текст.

    12. Дана строка символов. Требуется построить и вывести множество, элементами которого являются буквы, входящие в текст не менее двух раз.

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

    Контрольные вопросы

    1. Как описываются переменные типа множество?

    1. Какова максимально допустимая мощность множества?

    2. Как осуществляется ввод значений переменных типа множество?

    3. Как осуществляется вывод значений переменных типа множество?

    4. Какие операции допустимы над переменными типа множество?



    написать администратору сайта