Форум программистов, компьютерный форум, киберфорум
C# для начинающих
Войти
Регистрация
Восстановить пароль
Блоги Сообщество Поиск Заказать работу  
 
Рейтинг 4.62/21: Рейтинг темы: голосов - 21, средняя оценка - 4.62
 Аватар для karolina777
0 / 0 / 0
Регистрация: 19.01.2011
Сообщений: 14

Рекурсивная функция, проверяющяя, является ли симметричной часть символьного массива

20.01.2011, 22:19. Показов 4535. Ответов 5
Метки нет (Все метки)

Студворк — интернет-сервис помощи студентам
Уважаемые программисты,помогите пожалуйста студентке(заочнице) выполнить лабораторные работы на С#:

1.Написать рекурсивную логическую функцию simm(s,i,j), проверяющую,
является ли симетричной часть символьного массива s, начинающаяся i-ым
и кончающаяся j-ым ее элементами.

2. Написать процедуры, выполняющие операции над списком. Нахождение суммы последнего и предпоследнего элементов списка L.

3.операции с бинарными деревьями. Процедура вывода информации из всех листьев дерева в порядке возрастания.
0
Programming
Эксперт
39485 / 9562 / 3019
Регистрация: 12.04.2006
Сообщений: 41,671
Блог
20.01.2011, 22:19
Ответы с готовыми решениями:

Описать логическую функцию, проверяющую, является ли симметричной часть строки
Описать методы для выполнения следующих заданий двумя способами: через цикл и используя механизм рекурсии Описать логическую функцию simm...

Создать рекурсивную функцию summ(s, i, j), проверяющую, является ли симметричной часть строки s
Помогите пожалуйста написать программку я рекурсией. Необходимо создать рекурсивную функцию summ(s,i, j), проверяющую, является ли...

Описать рекурсивную логическую функцию Simm(S,I,J), проверяющую, является ли симметричной часть строки
Составить программы, использующие рекурсивные методы и печатающие результаты вычислений. Для исходных данных использовать генератор ...

5
 Аватар для Петррр
6721 / 3570 / 900
Регистрация: 28.10.2010
Сообщений: 5,937
20.01.2011, 22:32
А по подробнее можно задания растолковать?
0
 Аватар для karolina777
0 / 0 / 0
Регистрация: 19.01.2011
Сообщений: 14
20.01.2011, 23:00  [ТС]
второе задание я так поняла, что нужно создать список и выполнить операции над ним..в данном случае требуется найти сумму последнего и предпоследнего элементов списка L...
а вот в третье задание я не правильно написала...здесь нужно
Написать статическую функцию класса TNode в базовой программе Tree_
И дана Программа Tree_...и вот к этому нужно выполнить задание:Процедура вывода информации из всех листьев дерева в порядке возрастания...вот как-то так.

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
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
using System;
using System.Collections.Generic;
using System.Linq;
using System.Text;
 
namespace Tree_
{
   //Определение класса TreeNode - узла дерева
    public class TreeNode
    { 
        // Свойства класса
        internal TreeNode left= null;          // указатель на левый узел
        internal TreeNode right = null;        // указатель на  правый узел
        internal TreeNode Pr = null;           // указатель на  родителя узла
        internal int key = 0;
        internal string info = "";
/////////////////////////////////////////////////////////////////////////////
       //Функция статическая: "Создать новый  узел типа TreeNode"
        public static void Make_TreeNode(ref  TreeNode zNod)
        { 
             Console.WriteLine("Введите заначения key нового узла дерева ");
             string sKey = Console.ReadLine(); //ввод заначения sKey 
             int iKey = Convert.ToInt32(sKey); //преобразование sKey в целое 
             Console.WriteLine("Введите заначения info нового узла дерева ");
             string sInfo = Console.ReadLine();//ввод заначения sInfo string
             zNod. key = iKey;                 //определение свойства объекта
             zNod.info = sInfo;                //определение свойства объекта
             zNod.left= null;               
             zNod.right= null;               
             zNod.Pr= null;               
         }
/////////////////////////////////////////////////////////////////////////////
       //Функция статическая: "Добавить в дерево узел zNod  типа TreeNode"
        public static void Tree_Insert(ref  TreeNode rootNod, TreeNode zNod)
        { 
        //поиск места подключения нового узла
        TreeNode yNod = new TreeNode ();//указатель на родителя нового узла
        yNod = null;                        
        TreeNode xNod = new TreeNode ();//указательна сына родителя нового узла
        xNod = rootNod;                     
        while (xNod != null)              //цикл поиска узла-родителя нового узла
        {
            yNod = xNod;
            if (zNod.key<xNod.key) {xNod=xNod.left;}
                              else {xNod=xNod.right;}
        }
        zNod.Pr = yNod;                  // указатель на родителя нового узла
        //Вставка нового узла
        if (yNod != null)
        {
            if (zNod.key < yNod.key) { yNod.left = zNod; }   // левый сын 
                                else { yNod.right = zNod; }  // правый сын 
        }
            else { rootNod = zNod; }  // дерево пустое, новый узел - корень
        }
/////////////////////////////////////////////////////////////////////////////
//Функция статическая: "Создать дерево из n объектов типа TreeNode"
        public static void  Make_Tree(ref TreeNode rootNod)
        { 
        Console.WriteLine("Введите количество узлов дерева");
        string sNum = Console.ReadLine();
        int iNum = Convert.ToInt32(sNum);
        if (iNum > 0)
        {
            Console.WriteLine("Введите " + sNum + " узлов дерева через Enter");
            TreeNode.Make_TreeNode(ref rootNod);    //заполнение информацией 
        }
        for (int i = 2; i <= iNum; i++)
        {
            TreeNode zNod = new TreeNode();      // указатель нового узла
            TreeNode.Make_TreeNode(ref zNod);     // заполнение нового узла
            TreeNode.Tree_Insert(ref rootNod,zNod); // вставка узла  в дерево 
        }
        }
/////////////////////////////////////////////////////////////////////////////
// Функция: вывод значения key всех узлов дерева сверху,алгоритм рекурсивный
        public static void Order_Tree_Walk(TreeNode xNod)
        {
            if (xNod != null)
            {
                Console.Write(xNod.key + ",  ");  //напечатать key[xNod]            
                Order_Tree_Walk(xNod.left);
                Order_Tree_Walk(xNod.right);
            }
        }
///////////////////////////////////////////////////////////////////////////////
// Функция: вывод значения key всех узлов дерева слева, алгоритм рекурсивный
        public static void Inorder_Tree_Walk(TreeNode xNod)
        {
         if (xNod != null)
         {
             Inorder_Tree_Walk(xNod.left);
             Console.Write(xNod.key + ",  ");  //напечатать key[xNod]            
             Inorder_Tree_Walk(xNod.right);
         }
        }
/////////////////////////////////////////////////////////////////////////////
// Функция статическая: "Найти в дереве узел c максимальным значением поля key"
        public static void MaxElementInfo(ref int MaxEl, TreeNode NovN)
        {
            //...............................................
        }
    }
    public class Program
    {
        public static void Main(string[] args)
        {
            TreeNode rootTree = new TreeNode(); //указатель корня дерева
            string qName = "0";          //номер пункта меню
            while (qName != "6")             //цикл выбора пункта меню 
            {
                Console.WriteLine("-----------------------------------------");
                Console.WriteLine("1 Создать и заполнить информацией дерево");
                Console.WriteLine("2 Просмотреть  дерево сверху ...........");
                Console.WriteLine("3 Просмотреть  дерево слева ............");
                Console.WriteLine("4 Найти узел с максимальным значением key");
                Console.WriteLine("5 ......................................");
                Console.WriteLine("6 Выход.................................");
                Console.WriteLine("-----------------------------------------");
                Console.WriteLine("Введите номер пункта меню");
                qName = Console.ReadLine();
                switch (qName)
                {
                    case "1":
                        TreeNode.Make_Tree(ref rootTree);     //Создание дерева
                        break;
                    case "2":
                           TreeNode.Order_Tree_Walk(rootTree);//Просмотр сверху
                            Console.WriteLine("");
                            Console.WriteLine("---------------------------");
                            Console.WriteLine("Нажмите любую клавишу");
                            Console.ReadLine();
                        break;
                    case "3":
                            TreeNode.Inorder_Tree_Walk(rootTree);//Просм.слева
                            Console.WriteLine("");
                            Console.WriteLine("---------------------------");
                            Console.WriteLine("Нажмите любую клавишу");
                            Console.ReadLine();
                        break;
                    case "4":
                        //Поиск максимального числа в дереве 
                        //...................................
                        break;
                    case "5":
                        //...................................
                        break;
                    default:
                        break;
                }
            }
 
        }
    }
 
}
0
15 / 15 / 2
Регистрация: 24.07.2009
Сообщений: 59
21.01.2011, 14:54
1.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
using System;
 
namespace ConsoleApplication2
{
    class Program
    {
        private static bool Simm(string s, int i, int j)
        {
            if (i >= j) {return true;}
            else if (s[i] != s[j]) {return false;}
            else  return Simm(s, i + 1, j - 1);
        }
        static void Main(string[] args)
        {
            string s = "123454321";
            Console.WriteLine("result:{0}", Simm(s, 0, s.Length - 1).ToString());
            Console.ReadLine();
        }
    }
}
2.
C#
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
using System;
using System.Collections.Generic;
using System.Linq;
 
namespace ConsoleApplication1
{
    class Program
    {
        private static List<int> _list;
        private static int GetTwoElementSum(List<int> list, int first, int second)
        {
            return list.ElementAt(first) + list.ElementAt(second);
        }
        private static void Main(string[] args)
        {
            _list = new List<int> { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
            Console.WriteLine("rezultat:{0}", GetTwoElementSum(_list, _list.Count - 2, _list.Count -1));
            Console.ReadLine();
        }
    }
}
1
49 / 49 / 15
Регистрация: 13.08.2010
Сообщений: 160
21.01.2011, 17:46
C#
1
2
3
Func<String, Int32, Int32, Int32, Boolean> simm1 = null;
            simm1 = (s, i, j, end) => i == end ? true : s[i] == s[j] && simm1(s, i + 1, j - 1, end);
            Func<String, Int32, Int32, Boolean> simm = (s, i, j) => simm1(s, i, j, i + ((j - i) - ((j - i) % 2)) / 2);
Добавлено через 34 минуты
если предмет более математический нежели технический то это частично рекурсивная функция, обычно называется просто рекурсивной

если тебе нужна примитивно рекурсивная функция то это смерть, будет более 50 функций, вот к примеру для элементарной функции f(x) = 2x
следующая функция (# - будет вместо символа лямда тэрма)
Code
1
2
3
4
5
6
7
8
f1 = #x.x
f2 = #x.x+1
f3 = #x1.#x2.#x3.x2
f4 = f2f3
f5 - такая что справедливы следующие утверждения
f5(0)(x2) = f1(x2)
f5(y+1)(x2) = f4(y)(f5(y)(f5(y)(x2)))(x2)
f6 = f5(f1)(f2) <=> f = #x.2x
пример роботы
Code
1
2
3
f6(2) = f5(f1(2))(f1(2)) = f5(2)(f1(2)) = f5(2)(2) = f4(1)(f4(f5(1)(2))(2) = 
f4(1)(f4(0)(f5(0)(2))(2))(2) = f4(1)(f4(0)(2)(2))(2) =
f4(1)(f2(2))(2) = f4(1)(3)(2) = f2(f3(1)(3)(2)) = f2(3) = 4
покрайней мере когда мы изучали рекурсию от нас требовали давать все в виде примитивно рекурсивных функциях
правда мы хаскеле писали, а на шарпе учитывая то что он тупит с определениям лямда выражений
это антигуманно, да и задания жесть, один функциональный список что стоит зделать в примитивно рекурсивной форме

так что могу токо книги посоветовать

Х. Барендрет Ламбда-исчесление.Его синтаксис и семантика

Х. Роджерс Теория рекурсивных функций и эфективная вычислимость

книги бомба, на гугл даже не надейтесь

Добавлено через 2 минуты
ну а если предмет технический, то єто понты
0
 Аватар для агерон
447 / 300 / 65
Регистрация: 12.10.2009
Сообщений: 1,162
22.01.2011, 13:56
while(i)k++, мдя.... а ведь когда-то рекурсию делали на Бейсике фортране и паскале (молчу уже про С и С++). оказываеться рекурсия настолько сложная часть математики что нужно учить исчисление функций??? :-D по теме Рекурсия. и C# уже и не язык :-D а С++ наверное вообще уже умер вместе с Java
0
Надоела реклама? Зарегистрируйтесь и она исчезнет полностью.
inter-admin
Эксперт
29715 / 6470 / 2152
Регистрация: 06.03.2009
Сообщений: 28,500
Блог
22.01.2011, 13:56
Помогаю со студенческими работами здесь

Логическая функция: проверить, является ли симметричной часть строки, начинающаяся i-м и кончающаяся j-м её элементом
Здравствуйте, помогите, пожалуйста. Описать логическую функцию, проверяющую является ли симметричной часть строки, начинающаяся i-м и...

Описать логическую функцию, проверяющую является ли симметричной часть массива
Описать логическую функцию, проверяющую является ли симметричной часть массива, начинающегося i-м и кончающаяся j-м его элементом. Нужна...

Определить, является ли симметричной часть массива, начинающаяся i-м и кончающаяся j-m его элементом?
Описать логическую (нерекурсивную) функцию, проверяющую является ли симметричной часть массива, начинающаяся i-м и кончающаяся j-m его...

Описать логическую (возможно рекурсивную) функцию, проверяющую является ли симметричной часть массива
Описать логическую (возможно рекурсивную) функцию, проверяющую является ли симметричной часть массива, начинающаяся i-м и кончающаяся j-m...

Проверить, является ли симметричной часть строки
Описать рекурсивную логическую функцию simm(s:string; i,j:integer):boolean; проверяющую, является ли симметричной часть строки s,...


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

Или воспользуйтесь поиском по форуму:
6
Ответ Создать тему
Новые блоги и статьи
Ритм жизни
kumehtar 27.02.2026
Иногда приходится жить в ритме, где дел становится всё больше, а вовлечения в происходящее — всё меньше. Плотный график не даёт вниманию закрепиться ни на одном событии. Утро начинается с быстрых,. . .
SDL3 для Web (WebAssembly): Сборка библиотек SDL3 и Box2D из исходников с помощью CMake и Emscripten
8Observer8 27.02.2026
Недавно вышла версия SDL 3. 4. 2 библиотеки SDL3. На странице официальной релиза доступны исходники, готовые DLL (для x86, x64, arm64), а также библиотеки для разработки под Android, MinGW и Visual. . .
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. На борту пять. . .
Камера Toupcam IUA500KMA
Eddy_Em 12.02.2026
Т. к. у всяких "хикроботов" слишком уж мелкий пиксель, для подсмотра в ESPriF они вообще плохо годятся: уже 14 величину можно рассмотреть еле-еле лишь на экспозициях под 3 секунды (а то и больше),. . .
И ясному Солнцу
zbw 12.02.2026
И ясному Солнцу, и светлой Луне. В мире покоя нет и люди не могут жить в тишине. А жить им немного лет.
«Знание-Сила»
zbw 12.02.2026
«Знание-Сила» «Время-Деньги» «Деньги -Пуля»
КиберФорум - форум программистов, компьютерный форум, программирование
Powered by vBulletin
Copyright ©2000 - 2026, CyberForum.ru