Всем привет. Помогите проверить алгоритм. Алгоритм переберает все комбинации цифр и букв, сторки в 50 символов. Уж нему.
вот алгоритм. C# namespace WindowsFormsApplication8 ** public partial class Form1 : Form ** public string str = ""; public int DlinaStrok = 0; public Form1() ** InitializeComponent(); ** public void gette(int a, object sender) ** string c=""; for (int b = 0; b > 50; b++) ** if (DlinaStrok <= 50) ** c = char.ToString((char)a); str = str + c; listBox1.Items.Add(str); DlinaStrok = DlinaStrok + 1; ** else ** DlinaStrok = 0; str = ""; ** ** ** private void button1_Click(object sender, EventArgs e) ** for (int a = 48; (a >= 48) || (a <= 57) || (a >= 65) || (a <= 90) || (a >= 97) || (a <= 122); a++) ** gette(a,sender); ** for (int b = 1040; (b >= 1040) || (b <= 1105); b++) ** gette(b,sender); ** ** ** ** |
Re: алгоритм перебора знаков
Поступила информация о создателя темы, что тот, кто откомпилирует рабочий код на си шщарпе для данного алгоритма - получит бутылку коньяка!
|
Re: алгоритм перебора знаков
Цитата:
|
Re: алгоритм перебора знаков
Вот рабочий код на C#, неси коньяк.
using System; using System.Collections.Generic; using System.ComponentModel; using System.Data; using System.Drawing; using System.Linq; using System.Text; using System.Windows.Forms; namespace WindowsFormsApplication2 ** public partial class Form1 : Form ** public Form1() ** InitializeComponent(); ** public string str = ""; public int DlinaStrok = 0; public void gette(int a, object sender) ** string c = ""; for (int b = 0; b < 50; b++) ** if (DlinaStrok <= 50) ** c = char.ToString((char)a); str = str + c; listBox1.Items.Add(str); DlinaStrok = DlinaStrok + 1; ** else ** DlinaStrok = 0; str = ""; ** ** ** private void button1_Click(object sender, EventArgs e) ** for (int a = 48; a <= 122; a++) ** if (a >= 48 && a <= 57) ** gette(a, sender); ** if (a >= 65 && a <= 90) ** gette(a, sender); ** if (a >= 97 && a <= 122) ** gette(a, sender); ** ** for (int b = 1040; b <= 1105; b++) ** gette(b, sender); ** ** ** ** |
Re: алгоритм перебора знаков
Всем большое спосибо бутылка коньяка ушла админу форума.
|
Re: алгоритм перебора знаков
avrudoi, ты проверил код на работоспособность?
** надо заменить на левую скобку, это что то форум заменяет её. Ну и сам алгоритм твой изначальный неверный, его нужно дорабатывать. Сначала в массив вносишь все варианты "a" - от "0" до "Я" к примеру. Выбираешь все элементы массива максимальной длины. Потом уже к этому массиву добавляешь все варианты "a" - от "0" до "Я". И так цикл. Это уже сам доделывай. |
Re: алгоритм перебора знаков
Цитата:
как Должен работать алгоритм. Допустим нужно перебрать все варианты строки abc, это будет так выгледит, a, b, c, ab, ac, bc, ab, abc, acb, bac cab и т.д. при этом нуэно исключить повторные ваиранты, это наверника должен быть массив запоминающий все строки. |
Re: алгоритм перебора знаков
Цитата:
|
Re: алгоритм перебора знаков
Цитата:
|
Re: алгоритм перебора знаков
avrudoi, будет свободное время, займусь алгоритмом твоим.
|
Re: алгоритм перебора знаков
Цитата:
|
Re: алгоритм перебора знаков
Вот все таки я разобрался с твоим алгоритмом.
4-ядерный i5 3.3 ГГерц выполняет генерацию строк длиной 3 (в коде найди dlina <= 3) символа минут 10. Вот сам код программы: Код:
using System; |
Re: алгоритм перебора знаков
Агоримт работает.
|
Текущее время: 06:13. Часовой пояс GMT +2. |
Powered by vBulletin® Version 3.8.7
Copyright ©2000 - 2024, Jelsoft Enterprises Ltd. Перевод: zCarot