Lazarus
Home
Help
TinyPortal
Search
Login
Register
Lazarus
»
Forum
»
Free Pascal
»
Beginners
(Moderators:
FPK
,
Tomas Hajny
) »
FreePascal: find all 3-symbol unique substring in string
Free Pascal
Website
Downloads
Wiki
Documentation
Bugtracker
Mailing List
Lazarus
Website
Downloads (Laz+FPC)
Packages (OPM)
FAQ
Wiki
Documentation (RTL/FCL/LCL)
Bugtracker
CCR Bugs
IRC channel
GIT
Mailing List
Other languages
Foundation
Website
Useful Wiki Links
Project Roadmap
Getting the Source
Screenshots
How to use the forum
About donations (wiki)
Bookstore
Computer Math and Games in Pascal
(preview)
Lazarus Handbook
Search
Advanced search
Recent
Lazarus for Windows on aa...
by
Wallaby
[April 23, 2024, 11:46:56 pm]
Parameter passing odditie...
by
KodeZwerg
[April 23, 2024, 11:04:39 pm]
Can function be used for ...
by
jamie
[April 23, 2024, 10:53:10 pm]
(Solved) TIndexedAVLTree ...
by
lainz
[April 23, 2024, 10:49:03 pm]
Demo Scene Picture sinwav...
by
KodeZwerg
[April 23, 2024, 10:26:21 pm]
fkInternalCalc
by
zraja
[April 23, 2024, 09:31:07 pm]
A fairly simple sound sol...
by
KodeZwerg
[April 23, 2024, 09:23:37 pm]
add new targets to make
by
marcov
[April 23, 2024, 08:38:42 pm]
how to tweek fpmake to co...
by
marcov
[April 23, 2024, 08:29:16 pm]
Quirky windows
by
ASerge
[April 23, 2024, 07:07:16 pm]
[Request] Demo Scene Sub ...
by
Gigatron
[April 23, 2024, 06:29:39 pm]
Unlocking Files
by
KodeZwerg
[April 23, 2024, 06:03:08 pm]
[SOLVED] trunk bug for mi...
by
Key-Real
[April 23, 2024, 05:56:32 pm]
Demo Scene Bitmap Font Sc...
by
Gigatron
[April 23, 2024, 05:56:27 pm]
Compile/Convert Delphi pr...
by
Martin_fr
[April 23, 2024, 05:43:11 pm]
Generics - correct syntax
by
Thaddy
[April 23, 2024, 05:40:59 pm]
InstallAware Using Lazaru...
by
msintle
[April 23, 2024, 05:26:36 pm]
Xcode Command Line Tools ...
by
Joseph
[April 23, 2024, 05:16:39 pm]
Offical launch of the 1 B...
by
Hartmut
[April 23, 2024, 04:49:29 pm]
what to do if my target M...
by
nickysn
[April 23, 2024, 04:16:02 pm]
compiler error in unit
by
paule32
[April 23, 2024, 03:49:50 pm]
Multithreading - synchron...
by
mika
[April 23, 2024, 01:48:51 pm]
May be useful to somebody
by
KodeZwerg
[April 23, 2024, 12:38:22 pm]
match automatic highlight...
by
Чебурашка
[April 23, 2024, 11:35:14 am]
Tchart with dual numbers ...
by
wp
[April 23, 2024, 10:48:18 am]
« previous
next »
Print
Pages:
1
[
2
]
Author
Topic: FreePascal: find all 3-symbol unique substring in string (Read 10452 times)
winni
Hero Member
Posts: 3197
Re: FreePascal: find all 3-symbol unique substring in string
«
Reply #15 on:
January 13, 2022, 11:55:41 pm »
Hi!
Keep it short and simple:
Code: Pascal
[Select]
[+]
[-]
program
CountPattern
;
{$mode objfpc}{$H+}
uses
Classes
;
var
sl
:
TStringList
;
s
,
pattern
:
string
;
i
:
integer
;
begin
sl
:
=
TStringList
.
create
;
sl
.
Sorted
:
=
true
;
sl
.
Duplicates
:
=
dupIgnore
;
write
(
'String: '
)
;
readln
(
s
)
;
for
i
:
=
1
to
length
(
s
)
-
2
do
begin
pattern
:
=
copy
(
s
,
i
,
3
)
;
sl
.
add
(
pattern
)
;
end
;
writeln
(
sl
.
count
,
' unique patterns'
)
;
sl
.
free
;
end
.
Winni
PS.: DupIgnore does not work without Sorted.
If it is not a bug then it is strange.
Yes I know - another Delphi compatible bastard .....
«
Last Edit: January 14, 2022, 12:01:45 am by winni
»
Logged
Thaddy
Hero Member
Posts: 14382
Sensorship about opinions does not belong here.
Re: FreePascal: find all 3-symbol unique substring in string
«
Reply #16 on:
January 14, 2022, 10:08:43 am »
Well, it would be implementable, but it would be really slow. I guess that is the reason.
Logged
Object Pascal programmers should get rid of their "component fetish" especially with the non-visuals.
Thaddy
Hero Member
Posts: 14382
Sensorship about opinions does not belong here.
Re: FreePascal: find all 3-symbol unique substring in string
«
Reply #17 on:
January 14, 2022, 11:02:10 am »
Alternative that has just minor changes to your original code:
Use of
THashSet
- or if order is important
TSortedSet
- ,
For
instead of
foreach
and the addition uses
THashSet.add
.
Code: Pascal
[Select]
[+]
[-]
{$mode delphi}
uses
generics
.
collections
;
type
Mnoj
=
THashSet<string>
;
// or TSortedSet
var
S
:
string
;
i
:
integer
;
Mn3
:
Mnoj
;
begin
Mn3
:
=
Mnoj
.
Create
;
// or TSortedSet.Create
write
(
'String: '
)
;
readln
(
S
)
;
for
i
:
=
1
to
length
(
S
)
-
2
do
Mn3
.
Add
(
S
[
i
]
+
S
[
i
+
1
]
+
S
[
i
+
2
]
)
;
i
:
=
0
;
writeln
(
'Substring: '
)
;
for
S
in
Mn3
do
begin
Write
(
S
,
' '
)
;
i
:
=
i
+
1
;
end
;
writeln
;
writeln
(
'Sum='
,
i
)
;
Mn3
.
free
;
end
.
Voila. Works like a charm.
«
Last Edit: January 14, 2022, 11:05:57 am by Thaddy
»
Logged
Object Pascal programmers should get rid of their "component fetish" especially with the non-visuals.
BobDog
Sr. Member
Posts: 394
Re: FreePascal: find all 3-symbol unique substring in string
«
Reply #18 on:
January 14, 2022, 04:58:41 pm »
This is about as short as I can do this:
Code: Pascal
[Select]
[+]
[-]
program
threes
;
var
s
:
ansistring
;
i
:
int32
;
begin
while
(
s<>
'q'
)
do
begin
write
(
'Enter string (or q to quit): '
)
;
read
(
s
)
;
for
i
:
=
1
to
length
(
s
)
-
2
do
if
(
pos
(
(
s
[
i
..
i
+
2
]
)
,
s
)
=
i
)
then
writeln
(
i
,
' '
,
s
[
i
..
i
+
2
]
)
;
readln
;
end
;
end
.
Logged
Print
Pages:
1
[
2
]
« previous
next »
Lazarus
»
Forum
»
Free Pascal
»
Beginners
(Moderators:
FPK
,
Tomas Hajny
) »
FreePascal: find all 3-symbol unique substring in string
TinyPortal
© 2005-2018