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

Объясните код

18.10.2013, 13:58. Показов 1381. Ответов 4
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Пусть даны две строки str1 и str2. Необходимо выяснить, можно ли из str1 путём перестановки литер получить строку str2. Напишите подпрограмму, которая решала бы указанную задачу.
Если можно, то объясните подробно.
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
class Program
    {
        static bool Check(string str1, string str2)
        {
            bool t = true;
            string s1 = str1, s2 = str2;
            char c;
            if (str1.Length == str2.Length)
            {
                while(s1.Length > 0)
                {
                    c =s1[0];
                    s1 = s1.Remove(0,1);
                    if (s2.IndexOf(c) < 0)
                        t = false;
                    else
                        s2 = s2.Remove(s2.IndexOf(c), 1);
                }
            }
            else t = false;
            return t;
        }
 
        static void Main(string[] args)
        {
            Console.WriteLine("Введите str1:");
            string str1 = Console.ReadLine();
            Console.WriteLine("Введите str2:");
            string str2 = Console.ReadLine();
            if (Check(str1, str2))
                Console.WriteLine("str2 является перестановкой str1");
            else
                Console.WriteLine("str2 не является перестановкой str1");
            Console.ReadKey();
        }
    }
}
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
18.10.2013, 13:58
Ответы с готовыми решениями:

Объясните код
Перечислить все возрастающие последовательности длины k из чисел 1..n в лексикографическом порядке. (Пример: при n=5, k=2 получаем 12 13 14...

Объясните код
Можете пожалуйста объяснить код, только подробно. Вот условие:Вводится последовательность вещественных чисел, оканчивающаяся нулём, и...

Объясните код
Все вопросы задал в коде class Program { //Что это такое? public enum Organs: byte //Зачем нужно это...

4
154 / 153 / 29
Регистрация: 21.05.2010
Сообщений: 338
18.10.2013, 14:14
DeZMoniK, объясню метод Check(). В остальном, думаю, понятно:
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
static bool Check(string str1, string str2)
{
    bool t = true; // будет возвращать, можно ли составить или нет. Изначально якобы можно.
    string s1 = str1, s2 = str2;
    char c;
    if (str1.Length == str2.Length) // проверяем, чтобы длины строк были одинаковые
    {
        while(s1.Length > 0) // перебираем каждую букву в s1, пока не удалим все буквы из неё
        {
            c =s1[0]; // берём символ (букву) из строки (слова) s1
            s1 = s1.Remove(0,1); // удаляем этот символ из s1
            if (s2.IndexOf(c) < 0) // если в s2 найден символ c (буква из s1) - возвращается его индекс. Если индекс < 0 - значит символа в s2 нет и значит возвращаем ложь.
                t = false; // тут, кстати, лучше написать сразу return false, вместо t = false ибо дальше нет смысла проверять
            else
                s2 = s2.Remove(s2.IndexOf(c), 1); // а если в s2 найден символ - удаляем его из s2, чтобы больше он не попадался
        }
    }
    else t = false; // сюда мы попадём, если длины строк s1 и s2 разные.
    return t; // возвращаем результат
}
1
18.10.2013, 14:17

Не по теме:

довольно-таки интересная реализация :) я сначала подумал было составить список всех неповторяющихся перестановок, и потом смотреть, есть ли там искомое слово

0
Master of Orion
Эксперт .NET
 Аватар для Psilon
6102 / 4958 / 905
Регистрация: 10.07.2011
Сообщений: 14,522
Записей в блоге: 5
18.10.2013, 14:52
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
        static bool Check(string str1, string str2)
        {
            if (str1.Length != str2.Length)
                return false;
 
            var s1 = str1.ToCharArray();
            var s2 = str1.ToCharArray();
            Array.Sort(s1);
            Array.Sort(s2);
            for (int i = 0; i < s1.Length; i++)
            {
                if (s1[i] != s2[i])
                    return false;
            }
            return true;
        }
 
        static void Main(string[] args)
        {
            string s1 = "банка", s2 = "кабан";
 
            Console.WriteLine(Check(s1, s2));
        }
Добавлено через 2 минуты
Можно короче:
C#
1
2
3
4
5
6
7
8
9
10
11
        static bool Check(string str1, string str2)
        {
            if (str1.Length != str2.Length)
                return false;
 
            var s1 = str1.ToCharArray();
            var s2 = str1.ToCharArray();
            Array.Sort(s1);
            Array.Sort(s2);
            return !s1.Where((t, i) => t != s2[i]).Any();
        }
0
Эксперт .NET
 Аватар для kolorotur
17823 / 12973 / 3382
Регистрация: 17.09.2011
Сообщений: 21,261
18.10.2013, 15:19
Psilon, если уж линк, то можно еще так:
C#
1
2
3
4
5
6
7
8
9
10
11
        static bool Check(string str1, string str2)
        {
            if (str1.Length != str2.Length)
                return false;
 
            var s1 = str1.ToCharArray();
            var s2 = str1.ToCharArray();
            Array.Sort(s1);
            Array.Sort(s2);
            return s1.SequenceEqual(s2);
        }
Как вариант, можно через OrderBy, чтобы не плодить массивы.
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
18.10.2013, 15:19
Помогаю со студенческими работами здесь

Объясните код
Вот код: static int T(intr) { for(int i=0; i&lt;r.Length; i++) { if(r &lt; 0) { return i+1; ...

Объясните код
var list = new List&lt;int&gt;(); var cnt = 0; var tmp = arr; for(int j = 0; j &lt; arr.Length; j++) ...

Объясните Код
Можете пожалуйста объяснить код, только подробно. Вот условие:Вводится последовательность вещественных чисел, оканчивающаяся нулём, и...

Объясните код!
using System; class Program { static void Main(string args) { MyArray array = new MyArray(new int { 1, 2, 3,...

Объясните код
Объясните пожалуйста код, что делает и т.д. Буду признателен! :-using System; using System.Collections.Generic; using...


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

Или воспользуйтесь поиском по форуму:
5
Ответ Создать тему
Новые блоги и статьи
SDL3 для Web (WebAssembly): Синхронизация спрайтов SDL3 и тел Box2D
8Observer8 04.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-sync-physics-sprites-sdl3-c. zip На первой гифке отладочные линии отключены, а на второй включены:. . .
SDL3 для Web (WebAssembly): Идентификация объектов на Box2D v3 - использование userData и событий коллизий
8Observer8 02.03.2026
Содержание блога Финальная демка в браузере. Итоговый код: finish-collision-events-sdl3-c. zip https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11680&amp;d=1772460536 Одним из. . .
Реалии
Hrethgir 01.03.2026
Нет, я не закончил до сих пор симулятор. Эта задача сложнее. Не получилось уйти в плавсостав, но оно и к лучшему, возможно. Точнее получалось - но сварщиком в палубную команду, а это значит, в моём. . .
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек: SDL3, Box2D, FreeType, SDL3_ttf, SDL3_mixer и SDL3_image из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual Studio. . . .
SDL3 для Web (WebAssembly): Реализация движения на Box2D v3 - трение и коллизии с повёрнутыми стенами
8Observer8 20.02.2026
Содержание блога Box2D позволяет легко создать главного героя, который не проходит сквозь стены и перемещается с заданным трением о препятствия, которые можно располагать под углом, как верхнее. . .
Конвертировать закладки radiotray-ng в m3u-плейлист
damix 19.02.2026
Это можно сделать скриптом для PowerShell. Использование . \СonvertRadiotrayToM3U. ps1 <path_to_bookmarks. json> Рядом с файлом bookmarks. json появится файл bookmarks. m3u с результатом. # Check if. . .
Семь CDC на одном интерфейсе: 5 U[S]ARTов, 1 CAN и 1 SSI
Eddy_Em 18.02.2026
Постепенно допиливаю свою "многоинтерфейсную плату". Выглядит вот так: https:/ / www. cyberforum. ru/ blog_attachment. php?attachmentid=11617&stc=1&d=1771445347 Основана на STM32F303RBT6. На борту пять. . .
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru