Is there a smaller tautogram checker? [on hold]
$begingroup$
I got into code-golfing recently and tried to write the smallest tautogram checker.
A tautogram is a sentence in which all words start with the same letter, for example: Flowers flourish from France.
Given a sentence as input, determine whether it is a tautogram.
Test Cases
Flowers flourish from France
True
This is not a Tautogram
False
I came up with this python code (because it is my main language):
print(True if len(list(set([x.upper()[0] for x in __import__('sys').argv[1:]]))) == 1 else False)
Usage:
python3 tautogram.py Flowers flourish from France
# True
python3 tautogram.py This is not a Tautogram
# False
The sentence may contain commas and periods, but no other special characters, only upper and lower case letters and spaces.
Its size is 98 bytes. Is there a smaller solution in any language?
code-golf string decision-problem
New contributor
$endgroup$
put on hold as unclear what you're asking by Erik the Outgolfer, Stephen, Embodiment of Ignorance, Don Thousand, Jonathan Allan 23 hours ago
Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.
|
show 10 more comments
$begingroup$
I got into code-golfing recently and tried to write the smallest tautogram checker.
A tautogram is a sentence in which all words start with the same letter, for example: Flowers flourish from France.
Given a sentence as input, determine whether it is a tautogram.
Test Cases
Flowers flourish from France
True
This is not a Tautogram
False
I came up with this python code (because it is my main language):
print(True if len(list(set([x.upper()[0] for x in __import__('sys').argv[1:]]))) == 1 else False)
Usage:
python3 tautogram.py Flowers flourish from France
# True
python3 tautogram.py This is not a Tautogram
# False
The sentence may contain commas and periods, but no other special characters, only upper and lower case letters and spaces.
Its size is 98 bytes. Is there a smaller solution in any language?
code-golf string decision-problem
New contributor
$endgroup$
put on hold as unclear what you're asking by Erik the Outgolfer, Stephen, Embodiment of Ignorance, Don Thousand, Jonathan Allan 23 hours ago
Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.
1
$begingroup$
Is it intended as atips
question limited toPython
? If so, these both tags should be added.
$endgroup$
– Arnauld
yesterday
2
$begingroup$
Heya friend! This site is usually reserved for explicitly defined problems. Things like "can the input contain punctuation" should be answered before posting, but other than that this is a great first question comparatively to the other new-user questions we usually see. Judging by your examples I'd just clarify that the only characters in the input will be "[A-Za-z ]" and your question will be purely objective. I'd scope out some other questions around here, else this may honestly be a better fit on overflow.
$endgroup$
– Magic Octopus Urn
yesterday
1
$begingroup$
What do you mean by punctuation? Which characters are included?
$endgroup$
– Embodiment of Ignorance
yesterday
1
$begingroup$
@MagicOctopusUrn Sometimes when you ask for a short solution in stackOverflow the refer to this site :)
$endgroup$
– Luis felipe De jesus Munoz
yesterday
6
$begingroup$
Welcome to PPCG! A few more test cases (including punctuation) would be a great addition to this challenge.
$endgroup$
– AdmBorkBork
yesterday
|
show 10 more comments
$begingroup$
I got into code-golfing recently and tried to write the smallest tautogram checker.
A tautogram is a sentence in which all words start with the same letter, for example: Flowers flourish from France.
Given a sentence as input, determine whether it is a tautogram.
Test Cases
Flowers flourish from France
True
This is not a Tautogram
False
I came up with this python code (because it is my main language):
print(True if len(list(set([x.upper()[0] for x in __import__('sys').argv[1:]]))) == 1 else False)
Usage:
python3 tautogram.py Flowers flourish from France
# True
python3 tautogram.py This is not a Tautogram
# False
The sentence may contain commas and periods, but no other special characters, only upper and lower case letters and spaces.
Its size is 98 bytes. Is there a smaller solution in any language?
code-golf string decision-problem
New contributor
$endgroup$
I got into code-golfing recently and tried to write the smallest tautogram checker.
A tautogram is a sentence in which all words start with the same letter, for example: Flowers flourish from France.
Given a sentence as input, determine whether it is a tautogram.
Test Cases
Flowers flourish from France
True
This is not a Tautogram
False
I came up with this python code (because it is my main language):
print(True if len(list(set([x.upper()[0] for x in __import__('sys').argv[1:]]))) == 1 else False)
Usage:
python3 tautogram.py Flowers flourish from France
# True
python3 tautogram.py This is not a Tautogram
# False
The sentence may contain commas and periods, but no other special characters, only upper and lower case letters and spaces.
Its size is 98 bytes. Is there a smaller solution in any language?
code-golf string decision-problem
code-golf string decision-problem
New contributor
New contributor
edited 23 hours ago
trichoplax
7,50664276
7,50664276
New contributor
asked yesterday
Jaime TenorioJaime Tenorio
463
463
New contributor
New contributor
put on hold as unclear what you're asking by Erik the Outgolfer, Stephen, Embodiment of Ignorance, Don Thousand, Jonathan Allan 23 hours ago
Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.
put on hold as unclear what you're asking by Erik the Outgolfer, Stephen, Embodiment of Ignorance, Don Thousand, Jonathan Allan 23 hours ago
Please clarify your specific problem or add additional details to highlight exactly what you need. As it's currently written, it’s hard to tell exactly what you're asking. See the How to Ask page for help clarifying this question. If this question can be reworded to fit the rules in the help center, please edit the question.
1
$begingroup$
Is it intended as atips
question limited toPython
? If so, these both tags should be added.
$endgroup$
– Arnauld
yesterday
2
$begingroup$
Heya friend! This site is usually reserved for explicitly defined problems. Things like "can the input contain punctuation" should be answered before posting, but other than that this is a great first question comparatively to the other new-user questions we usually see. Judging by your examples I'd just clarify that the only characters in the input will be "[A-Za-z ]" and your question will be purely objective. I'd scope out some other questions around here, else this may honestly be a better fit on overflow.
$endgroup$
– Magic Octopus Urn
yesterday
1
$begingroup$
What do you mean by punctuation? Which characters are included?
$endgroup$
– Embodiment of Ignorance
yesterday
1
$begingroup$
@MagicOctopusUrn Sometimes when you ask for a short solution in stackOverflow the refer to this site :)
$endgroup$
– Luis felipe De jesus Munoz
yesterday
6
$begingroup$
Welcome to PPCG! A few more test cases (including punctuation) would be a great addition to this challenge.
$endgroup$
– AdmBorkBork
yesterday
|
show 10 more comments
1
$begingroup$
Is it intended as atips
question limited toPython
? If so, these both tags should be added.
$endgroup$
– Arnauld
yesterday
2
$begingroup$
Heya friend! This site is usually reserved for explicitly defined problems. Things like "can the input contain punctuation" should be answered before posting, but other than that this is a great first question comparatively to the other new-user questions we usually see. Judging by your examples I'd just clarify that the only characters in the input will be "[A-Za-z ]" and your question will be purely objective. I'd scope out some other questions around here, else this may honestly be a better fit on overflow.
$endgroup$
– Magic Octopus Urn
yesterday
1
$begingroup$
What do you mean by punctuation? Which characters are included?
$endgroup$
– Embodiment of Ignorance
yesterday
1
$begingroup$
@MagicOctopusUrn Sometimes when you ask for a short solution in stackOverflow the refer to this site :)
$endgroup$
– Luis felipe De jesus Munoz
yesterday
6
$begingroup$
Welcome to PPCG! A few more test cases (including punctuation) would be a great addition to this challenge.
$endgroup$
– AdmBorkBork
yesterday
1
1
$begingroup$
Is it intended as a
tips
question limited to Python
? If so, these both tags should be added.$endgroup$
– Arnauld
yesterday
$begingroup$
Is it intended as a
tips
question limited to Python
? If so, these both tags should be added.$endgroup$
– Arnauld
yesterday
2
2
$begingroup$
Heya friend! This site is usually reserved for explicitly defined problems. Things like "can the input contain punctuation" should be answered before posting, but other than that this is a great first question comparatively to the other new-user questions we usually see. Judging by your examples I'd just clarify that the only characters in the input will be "[A-Za-z ]" and your question will be purely objective. I'd scope out some other questions around here, else this may honestly be a better fit on overflow.
$endgroup$
– Magic Octopus Urn
yesterday
$begingroup$
Heya friend! This site is usually reserved for explicitly defined problems. Things like "can the input contain punctuation" should be answered before posting, but other than that this is a great first question comparatively to the other new-user questions we usually see. Judging by your examples I'd just clarify that the only characters in the input will be "[A-Za-z ]" and your question will be purely objective. I'd scope out some other questions around here, else this may honestly be a better fit on overflow.
$endgroup$
– Magic Octopus Urn
yesterday
1
1
$begingroup$
What do you mean by punctuation? Which characters are included?
$endgroup$
– Embodiment of Ignorance
yesterday
$begingroup$
What do you mean by punctuation? Which characters are included?
$endgroup$
– Embodiment of Ignorance
yesterday
1
1
$begingroup$
@MagicOctopusUrn Sometimes when you ask for a short solution in stackOverflow the refer to this site :)
$endgroup$
– Luis felipe De jesus Munoz
yesterday
$begingroup$
@MagicOctopusUrn Sometimes when you ask for a short solution in stackOverflow the refer to this site :)
$endgroup$
– Luis felipe De jesus Munoz
yesterday
6
6
$begingroup$
Welcome to PPCG! A few more test cases (including punctuation) would be a great addition to this challenge.
$endgroup$
– AdmBorkBork
yesterday
$begingroup$
Welcome to PPCG! A few more test cases (including punctuation) would be a great addition to this challenge.
$endgroup$
– AdmBorkBork
yesterday
|
show 10 more comments
13 Answers
13
active
oldest
votes
$begingroup$
05AB1E, 5 bytes
l#€нË
Try it online!
l # Lowercase input.
# # Split on spaces.
€н # a[0] of each.
Ë # All equal?
Did this on mobile excuse the no explanation.
$endgroup$
add a comment |
$begingroup$
Python 2, 47 bytes
lambda s:len(set(zip(*s.lower().split())[0]))<2
Try it online!
Came up with this on mobile. Can probably be golfed more.
$endgroup$
add a comment |
$begingroup$
Clojure, 80 bytes
Try it online!. TIO doesn't support Clojure's standard String library though, so the first version will throw a "Can't find lower-case" error.
(fn[s](use '[clojure.string])(apply =(map first(map lower-case(split s #" ")))))
Ungolfed:
(defn tautogram? [s]
(use '[clojure.string])
(->> (split s #" ") ; Get words
(map lower-case)
(map first) ; Get first letter of each word
(apply =))) ; And make sure they're all the same
I made a version that avoids the import:
(fn [s](apply =(map #(if(<(-(int %)32)65)(int %)(-(int %) 32))(map first(take-nth 2(partition-by #(= % )s))))))
; -----
(defn tautogram? [s]
(->> s
(partition-by #(= % )) ; Split into words
(take-nth 2) ; Remove spaces
(map first) ; Get first letter
; Convert to uppercased letter code
(map #(if (< (- (int %) 32) 65) ; If attempting to uppercase puts the letter out of range,
(int %) ; Go with the current code
(- (int %) 32))) ; Else go with the uppercased code
(apply =))) ; And check if they're all equal
But it's 112 Bytes.
$endgroup$
$begingroup$
Here's my Racket solution:(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Much shorter in PicoLisp:(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
add a comment |
$begingroup$
PowerShell, 57 50 41 bytes
(-split$args|% s*g 0 1|sort -u).count-eq1
Try it online!
Takes input and split
s it on whitespace. Loops through each word, and grabs the first letter by taking the s
ubstring
starting at position 0
and going for 1
character. Then sort
s the letters (case-insensitive by default) with the -u
nique flag to pull out only one copy of each letter, and verifies the count
of those names are -eq
ual to 1
. Output is implicit.
-9 bytes thanks to mazzy.
$endgroup$
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
1
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
add a comment |
$begingroup$
05AB1E (legacy), 5 bytes
#€¬uË
Try it online!
# // split on spaces
€¬ // get the first letter of each word
uË // check if they're the same (uppercase) letter
$endgroup$
add a comment |
$begingroup$
Brachylog, 5 bytes
ḷṇ₁hᵛ
Try it online!
The input
ḷ lowercased
ṇ₁ and split on spaces
hᵛ is a list of elements which all start with the same thing.
$endgroup$
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
add a comment |
$begingroup$
Haskell, 71 bytes
f s|c<-fromEnum.head<$>words s=all(`elem`[-32,0,32]).zipWith(-)c$tail c
Try it online!
Haskell, 61 58 bytes (using Data.Char.toLower
)
- Saved three bytes thanks to nimi.
import Data.Char
(all=<<(==).head).(toLower.head<$>).words
Try it online!
$endgroup$
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
add a comment |
$begingroup$
Perl 5 (-p
), 20 bytes
$_=!/^(.).* (?!1)/i
TIO
following comments in case bad punctuation (31 bytes)
$_=!/^W*+(.).*(?=bw)(?!1)/i
31 bytes
otherwise there's another approach, also with 31 bytes:
$h{ord()%32}++for/w+/g;$_=2>%h
31 bytes other
$endgroup$
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
add a comment |
$begingroup$
JavaScript (Node.js), 54 bytes
s=>!s.match(/bw+/g).some(p=s=>p-(p=Buffer(s)[0]&31))
Try it online!
Or 47 bytes if each word (but the first) is guaranteed to be preceded by a space.
$endgroup$
$begingroup$
or in one regex or with a space instead ofW
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
@NahuelFouilleul, usingtest
saves another byte.
$endgroup$
– Shaggy
yesterday
1
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
add a comment |
$begingroup$
Japt -¡
, 5 bytes
¸mÎro
Try it
¸mÎro :Implicit input of string
¸ :Split on spaces
m :Map
Î : Get first character
r :Reduce by
o : Keeping the characters that appear in both, case-insensitive
:Implicit output as boolean
$endgroup$
add a comment |
$begingroup$
C# (Visual C# Interactive Compiler), 41 bytes
n=>n.Split().GroupBy(c=>c[0]|32).Single()
Throws an exception if false, nothing if true.
Try it online!
$endgroup$
add a comment |
$begingroup$
Perl 6, 19 bytes
{[eq] m:g/<<./}o&lc
Try it online!
$endgroup$
add a comment |
$begingroup$
Java, (36 bytes)
s->!s.matches("(?i)(.).* (?!\1).*")
TIO
$endgroup$
1
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string
$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
add a comment |
13 Answers
13
active
oldest
votes
13 Answers
13
active
oldest
votes
active
oldest
votes
active
oldest
votes
$begingroup$
05AB1E, 5 bytes
l#€нË
Try it online!
l # Lowercase input.
# # Split on spaces.
€н # a[0] of each.
Ë # All equal?
Did this on mobile excuse the no explanation.
$endgroup$
add a comment |
$begingroup$
05AB1E, 5 bytes
l#€нË
Try it online!
l # Lowercase input.
# # Split on spaces.
€н # a[0] of each.
Ë # All equal?
Did this on mobile excuse the no explanation.
$endgroup$
add a comment |
$begingroup$
05AB1E, 5 bytes
l#€нË
Try it online!
l # Lowercase input.
# # Split on spaces.
€н # a[0] of each.
Ë # All equal?
Did this on mobile excuse the no explanation.
$endgroup$
05AB1E, 5 bytes
l#€нË
Try it online!
l # Lowercase input.
# # Split on spaces.
€н # a[0] of each.
Ë # All equal?
Did this on mobile excuse the no explanation.
edited 8 hours ago
Jo King
25.5k362129
25.5k362129
answered yesterday
Magic Octopus UrnMagic Octopus Urn
12.8k444126
12.8k444126
add a comment |
add a comment |
$begingroup$
Python 2, 47 bytes
lambda s:len(set(zip(*s.lower().split())[0]))<2
Try it online!
Came up with this on mobile. Can probably be golfed more.
$endgroup$
add a comment |
$begingroup$
Python 2, 47 bytes
lambda s:len(set(zip(*s.lower().split())[0]))<2
Try it online!
Came up with this on mobile. Can probably be golfed more.
$endgroup$
add a comment |
$begingroup$
Python 2, 47 bytes
lambda s:len(set(zip(*s.lower().split())[0]))<2
Try it online!
Came up with this on mobile. Can probably be golfed more.
$endgroup$
Python 2, 47 bytes
lambda s:len(set(zip(*s.lower().split())[0]))<2
Try it online!
Came up with this on mobile. Can probably be golfed more.
answered yesterday
TFeldTFeld
16.1k21449
16.1k21449
add a comment |
add a comment |
$begingroup$
Clojure, 80 bytes
Try it online!. TIO doesn't support Clojure's standard String library though, so the first version will throw a "Can't find lower-case" error.
(fn[s](use '[clojure.string])(apply =(map first(map lower-case(split s #" ")))))
Ungolfed:
(defn tautogram? [s]
(use '[clojure.string])
(->> (split s #" ") ; Get words
(map lower-case)
(map first) ; Get first letter of each word
(apply =))) ; And make sure they're all the same
I made a version that avoids the import:
(fn [s](apply =(map #(if(<(-(int %)32)65)(int %)(-(int %) 32))(map first(take-nth 2(partition-by #(= % )s))))))
; -----
(defn tautogram? [s]
(->> s
(partition-by #(= % )) ; Split into words
(take-nth 2) ; Remove spaces
(map first) ; Get first letter
; Convert to uppercased letter code
(map #(if (< (- (int %) 32) 65) ; If attempting to uppercase puts the letter out of range,
(int %) ; Go with the current code
(- (int %) 32))) ; Else go with the uppercased code
(apply =))) ; And check if they're all equal
But it's 112 Bytes.
$endgroup$
$begingroup$
Here's my Racket solution:(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Much shorter in PicoLisp:(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
add a comment |
$begingroup$
Clojure, 80 bytes
Try it online!. TIO doesn't support Clojure's standard String library though, so the first version will throw a "Can't find lower-case" error.
(fn[s](use '[clojure.string])(apply =(map first(map lower-case(split s #" ")))))
Ungolfed:
(defn tautogram? [s]
(use '[clojure.string])
(->> (split s #" ") ; Get words
(map lower-case)
(map first) ; Get first letter of each word
(apply =))) ; And make sure they're all the same
I made a version that avoids the import:
(fn [s](apply =(map #(if(<(-(int %)32)65)(int %)(-(int %) 32))(map first(take-nth 2(partition-by #(= % )s))))))
; -----
(defn tautogram? [s]
(->> s
(partition-by #(= % )) ; Split into words
(take-nth 2) ; Remove spaces
(map first) ; Get first letter
; Convert to uppercased letter code
(map #(if (< (- (int %) 32) 65) ; If attempting to uppercase puts the letter out of range,
(int %) ; Go with the current code
(- (int %) 32))) ; Else go with the uppercased code
(apply =))) ; And check if they're all equal
But it's 112 Bytes.
$endgroup$
$begingroup$
Here's my Racket solution:(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Much shorter in PicoLisp:(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
add a comment |
$begingroup$
Clojure, 80 bytes
Try it online!. TIO doesn't support Clojure's standard String library though, so the first version will throw a "Can't find lower-case" error.
(fn[s](use '[clojure.string])(apply =(map first(map lower-case(split s #" ")))))
Ungolfed:
(defn tautogram? [s]
(use '[clojure.string])
(->> (split s #" ") ; Get words
(map lower-case)
(map first) ; Get first letter of each word
(apply =))) ; And make sure they're all the same
I made a version that avoids the import:
(fn [s](apply =(map #(if(<(-(int %)32)65)(int %)(-(int %) 32))(map first(take-nth 2(partition-by #(= % )s))))))
; -----
(defn tautogram? [s]
(->> s
(partition-by #(= % )) ; Split into words
(take-nth 2) ; Remove spaces
(map first) ; Get first letter
; Convert to uppercased letter code
(map #(if (< (- (int %) 32) 65) ; If attempting to uppercase puts the letter out of range,
(int %) ; Go with the current code
(- (int %) 32))) ; Else go with the uppercased code
(apply =))) ; And check if they're all equal
But it's 112 Bytes.
$endgroup$
Clojure, 80 bytes
Try it online!. TIO doesn't support Clojure's standard String library though, so the first version will throw a "Can't find lower-case" error.
(fn[s](use '[clojure.string])(apply =(map first(map lower-case(split s #" ")))))
Ungolfed:
(defn tautogram? [s]
(use '[clojure.string])
(->> (split s #" ") ; Get words
(map lower-case)
(map first) ; Get first letter of each word
(apply =))) ; And make sure they're all the same
I made a version that avoids the import:
(fn [s](apply =(map #(if(<(-(int %)32)65)(int %)(-(int %) 32))(map first(take-nth 2(partition-by #(= % )s))))))
; -----
(defn tautogram? [s]
(->> s
(partition-by #(= % )) ; Split into words
(take-nth 2) ; Remove spaces
(map first) ; Get first letter
; Convert to uppercased letter code
(map #(if (< (- (int %) 32) 65) ; If attempting to uppercase puts the letter out of range,
(int %) ; Go with the current code
(- (int %) 32))) ; Else go with the uppercased code
(apply =))) ; And check if they're all equal
But it's 112 Bytes.
edited 23 hours ago
answered 23 hours ago
CarcigenicateCarcigenicate
2,33911224
2,33911224
$begingroup$
Here's my Racket solution:(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Much shorter in PicoLisp:(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
add a comment |
$begingroup$
Here's my Racket solution:(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Much shorter in PicoLisp:(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
$begingroup$
Here's my Racket solution:
(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Here's my Racket solution:
(define(f s)(apply char=?(map(λ(x)(char-upcase(car(string->list x))))(string-split s))))
$endgroup$
– Galen Ivanov
14 hours ago
$begingroup$
Much shorter in PicoLisp:
(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
$begingroup$
Much shorter in PicoLisp:
(de f(s)(apply =(mapcar car(split(chop(lowc s))" "))))
$endgroup$
– Galen Ivanov
13 hours ago
add a comment |
$begingroup$
PowerShell, 57 50 41 bytes
(-split$args|% s*g 0 1|sort -u).count-eq1
Try it online!
Takes input and split
s it on whitespace. Loops through each word, and grabs the first letter by taking the s
ubstring
starting at position 0
and going for 1
character. Then sort
s the letters (case-insensitive by default) with the -u
nique flag to pull out only one copy of each letter, and verifies the count
of those names are -eq
ual to 1
. Output is implicit.
-9 bytes thanks to mazzy.
$endgroup$
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
1
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
add a comment |
$begingroup$
PowerShell, 57 50 41 bytes
(-split$args|% s*g 0 1|sort -u).count-eq1
Try it online!
Takes input and split
s it on whitespace. Loops through each word, and grabs the first letter by taking the s
ubstring
starting at position 0
and going for 1
character. Then sort
s the letters (case-insensitive by default) with the -u
nique flag to pull out only one copy of each letter, and verifies the count
of those names are -eq
ual to 1
. Output is implicit.
-9 bytes thanks to mazzy.
$endgroup$
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
1
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
add a comment |
$begingroup$
PowerShell, 57 50 41 bytes
(-split$args|% s*g 0 1|sort -u).count-eq1
Try it online!
Takes input and split
s it on whitespace. Loops through each word, and grabs the first letter by taking the s
ubstring
starting at position 0
and going for 1
character. Then sort
s the letters (case-insensitive by default) with the -u
nique flag to pull out only one copy of each letter, and verifies the count
of those names are -eq
ual to 1
. Output is implicit.
-9 bytes thanks to mazzy.
$endgroup$
PowerShell, 57 50 41 bytes
(-split$args|% s*g 0 1|sort -u).count-eq1
Try it online!
Takes input and split
s it on whitespace. Loops through each word, and grabs the first letter by taking the s
ubstring
starting at position 0
and going for 1
character. Then sort
s the letters (case-insensitive by default) with the -u
nique flag to pull out only one copy of each letter, and verifies the count
of those names are -eq
ual to 1
. Output is implicit.
-9 bytes thanks to mazzy.
edited 9 hours ago
answered yesterday
AdmBorkBorkAdmBorkBork
27.5k466237
27.5k466237
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
1
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
add a comment |
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
1
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
41 bytes
$endgroup$
– mazzy
15 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
$begingroup$
35 bytes with regexp
$endgroup$
– mazzy
13 hours ago
1
1
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy fixed trying to understand the intention
$endgroup$
– Nahuel Fouilleul
12 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
@mazzy I'll let you post the regex version when the question is reopened. It's different enough to warrant its own answer.
$endgroup$
– AdmBorkBork
8 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
$begingroup$
I'm agree. but this question is put on hold, so I can't create a new answer.
$endgroup$
– mazzy
6 hours ago
add a comment |
$begingroup$
05AB1E (legacy), 5 bytes
#€¬uË
Try it online!
# // split on spaces
€¬ // get the first letter of each word
uË // check if they're the same (uppercase) letter
$endgroup$
add a comment |
$begingroup$
05AB1E (legacy), 5 bytes
#€¬uË
Try it online!
# // split on spaces
€¬ // get the first letter of each word
uË // check if they're the same (uppercase) letter
$endgroup$
add a comment |
$begingroup$
05AB1E (legacy), 5 bytes
#€¬uË
Try it online!
# // split on spaces
€¬ // get the first letter of each word
uË // check if they're the same (uppercase) letter
$endgroup$
05AB1E (legacy), 5 bytes
#€¬uË
Try it online!
# // split on spaces
€¬ // get the first letter of each word
uË // check if they're the same (uppercase) letter
answered yesterday
RileyRiley
11k11448
11k11448
add a comment |
add a comment |
$begingroup$
Brachylog, 5 bytes
ḷṇ₁hᵛ
Try it online!
The input
ḷ lowercased
ṇ₁ and split on spaces
hᵛ is a list of elements which all start with the same thing.
$endgroup$
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
add a comment |
$begingroup$
Brachylog, 5 bytes
ḷṇ₁hᵛ
Try it online!
The input
ḷ lowercased
ṇ₁ and split on spaces
hᵛ is a list of elements which all start with the same thing.
$endgroup$
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
add a comment |
$begingroup$
Brachylog, 5 bytes
ḷṇ₁hᵛ
Try it online!
The input
ḷ lowercased
ṇ₁ and split on spaces
hᵛ is a list of elements which all start with the same thing.
$endgroup$
Brachylog, 5 bytes
ḷṇ₁hᵛ
Try it online!
The input
ḷ lowercased
ṇ₁ and split on spaces
hᵛ is a list of elements which all start with the same thing.
answered 23 hours ago
Unrelated StringUnrelated String
1,381211
1,381211
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
add a comment |
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
$begingroup$
I just now noticed that this has to be able to handle punctuation, but without any punctuated test cases I can't tell if this does or doesn't still work...
$endgroup$
– Unrelated String
23 hours ago
add a comment |
$begingroup$
Haskell, 71 bytes
f s|c<-fromEnum.head<$>words s=all(`elem`[-32,0,32]).zipWith(-)c$tail c
Try it online!
Haskell, 61 58 bytes (using Data.Char.toLower
)
- Saved three bytes thanks to nimi.
import Data.Char
(all=<<(==).head).(toLower.head<$>).words
Try it online!
$endgroup$
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
add a comment |
$begingroup$
Haskell, 71 bytes
f s|c<-fromEnum.head<$>words s=all(`elem`[-32,0,32]).zipWith(-)c$tail c
Try it online!
Haskell, 61 58 bytes (using Data.Char.toLower
)
- Saved three bytes thanks to nimi.
import Data.Char
(all=<<(==).head).(toLower.head<$>).words
Try it online!
$endgroup$
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
add a comment |
$begingroup$
Haskell, 71 bytes
f s|c<-fromEnum.head<$>words s=all(`elem`[-32,0,32]).zipWith(-)c$tail c
Try it online!
Haskell, 61 58 bytes (using Data.Char.toLower
)
- Saved three bytes thanks to nimi.
import Data.Char
(all=<<(==).head).(toLower.head<$>).words
Try it online!
$endgroup$
Haskell, 71 bytes
f s|c<-fromEnum.head<$>words s=all(`elem`[-32,0,32]).zipWith(-)c$tail c
Try it online!
Haskell, 61 58 bytes (using Data.Char.toLower
)
- Saved three bytes thanks to nimi.
import Data.Char
(all=<<(==).head).(toLower.head<$>).words
Try it online!
edited 22 hours ago
answered yesterday
Jonathan FrechJonathan Frech
6,47311040
6,47311040
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
add a comment |
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
$begingroup$
@nimi Thank you.
$endgroup$
– Jonathan Frech
22 hours ago
add a comment |
$begingroup$
Perl 5 (-p
), 20 bytes
$_=!/^(.).* (?!1)/i
TIO
following comments in case bad punctuation (31 bytes)
$_=!/^W*+(.).*(?=bw)(?!1)/i
31 bytes
otherwise there's another approach, also with 31 bytes:
$h{ord()%32}++for/w+/g;$_=2>%h
31 bytes other
$endgroup$
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
add a comment |
$begingroup$
Perl 5 (-p
), 20 bytes
$_=!/^(.).* (?!1)/i
TIO
following comments in case bad punctuation (31 bytes)
$_=!/^W*+(.).*(?=bw)(?!1)/i
31 bytes
otherwise there's another approach, also with 31 bytes:
$h{ord()%32}++for/w+/g;$_=2>%h
31 bytes other
$endgroup$
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
add a comment |
$begingroup$
Perl 5 (-p
), 20 bytes
$_=!/^(.).* (?!1)/i
TIO
following comments in case bad punctuation (31 bytes)
$_=!/^W*+(.).*(?=bw)(?!1)/i
31 bytes
otherwise there's another approach, also with 31 bytes:
$h{ord()%32}++for/w+/g;$_=2>%h
31 bytes other
$endgroup$
Perl 5 (-p
), 20 bytes
$_=!/^(.).* (?!1)/i
TIO
following comments in case bad punctuation (31 bytes)
$_=!/^W*+(.).*(?=bw)(?!1)/i
31 bytes
otherwise there's another approach, also with 31 bytes:
$h{ord()%32}++for/w+/g;$_=2>%h
31 bytes other
edited 10 hours ago
answered yesterday
Nahuel FouilleulNahuel Fouilleul
2,925211
2,925211
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
add a comment |
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
what about punctuations? what about spaces or punctuations at the strart of string?
$endgroup$
– mazzy
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be
$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
this answer works for the given test cases, could be improved depending the requirements could be
$_=!/^W*+(.).*(?=bw)(?!1)/i
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
$begingroup$
but reading carefuly the question and the given solution, spaces at beginning can't occur because the spaces are used by the shell to split the arguments. The program checks only that all arguments start with the same character
$endgroup$
– Nahuel Fouilleul
13 hours ago
add a comment |
$begingroup$
JavaScript (Node.js), 54 bytes
s=>!s.match(/bw+/g).some(p=s=>p-(p=Buffer(s)[0]&31))
Try it online!
Or 47 bytes if each word (but the first) is guaranteed to be preceded by a space.
$endgroup$
$begingroup$
or in one regex or with a space instead ofW
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
@NahuelFouilleul, usingtest
saves another byte.
$endgroup$
– Shaggy
yesterday
1
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
add a comment |
$begingroup$
JavaScript (Node.js), 54 bytes
s=>!s.match(/bw+/g).some(p=s=>p-(p=Buffer(s)[0]&31))
Try it online!
Or 47 bytes if each word (but the first) is guaranteed to be preceded by a space.
$endgroup$
$begingroup$
or in one regex or with a space instead ofW
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
@NahuelFouilleul, usingtest
saves another byte.
$endgroup$
– Shaggy
yesterday
1
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
add a comment |
$begingroup$
JavaScript (Node.js), 54 bytes
s=>!s.match(/bw+/g).some(p=s=>p-(p=Buffer(s)[0]&31))
Try it online!
Or 47 bytes if each word (but the first) is guaranteed to be preceded by a space.
$endgroup$
JavaScript (Node.js), 54 bytes
s=>!s.match(/bw+/g).some(p=s=>p-(p=Buffer(s)[0]&31))
Try it online!
Or 47 bytes if each word (but the first) is guaranteed to be preceded by a space.
answered yesterday
ArnauldArnauld
79.8k797330
79.8k797330
$begingroup$
or in one regex or with a space instead ofW
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
@NahuelFouilleul, usingtest
saves another byte.
$endgroup$
– Shaggy
yesterday
1
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
add a comment |
$begingroup$
or in one regex or with a space instead ofW
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
@NahuelFouilleul, usingtest
saves another byte.
$endgroup$
– Shaggy
yesterday
1
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
or in one regex or with a space instead of
W
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
or in one regex or with a space instead of
W
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
@NahuelFouilleul, using
test
saves another byte.$endgroup$
– Shaggy
yesterday
$begingroup$
@NahuelFouilleul, using
test
saves another byte.$endgroup$
– Shaggy
yesterday
1
1
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
@NahuelFouilleul You should probably post is separately.
$endgroup$
– Arnauld
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
$begingroup$
already posted the perl version, i don't master as well javascript, i'm happy to give you a hint
$endgroup$
– Nahuel Fouilleul
yesterday
add a comment |
$begingroup$
Japt -¡
, 5 bytes
¸mÎro
Try it
¸mÎro :Implicit input of string
¸ :Split on spaces
m :Map
Î : Get first character
r :Reduce by
o : Keeping the characters that appear in both, case-insensitive
:Implicit output as boolean
$endgroup$
add a comment |
$begingroup$
Japt -¡
, 5 bytes
¸mÎro
Try it
¸mÎro :Implicit input of string
¸ :Split on spaces
m :Map
Î : Get first character
r :Reduce by
o : Keeping the characters that appear in both, case-insensitive
:Implicit output as boolean
$endgroup$
add a comment |
$begingroup$
Japt -¡
, 5 bytes
¸mÎro
Try it
¸mÎro :Implicit input of string
¸ :Split on spaces
m :Map
Î : Get first character
r :Reduce by
o : Keeping the characters that appear in both, case-insensitive
:Implicit output as boolean
$endgroup$
Japt -¡
, 5 bytes
¸mÎro
Try it
¸mÎro :Implicit input of string
¸ :Split on spaces
m :Map
Î : Get first character
r :Reduce by
o : Keeping the characters that appear in both, case-insensitive
:Implicit output as boolean
answered yesterday
ShaggyShaggy
19k21667
19k21667
add a comment |
add a comment |
$begingroup$
C# (Visual C# Interactive Compiler), 41 bytes
n=>n.Split().GroupBy(c=>c[0]|32).Single()
Throws an exception if false, nothing if true.
Try it online!
$endgroup$
add a comment |
$begingroup$
C# (Visual C# Interactive Compiler), 41 bytes
n=>n.Split().GroupBy(c=>c[0]|32).Single()
Throws an exception if false, nothing if true.
Try it online!
$endgroup$
add a comment |
$begingroup$
C# (Visual C# Interactive Compiler), 41 bytes
n=>n.Split().GroupBy(c=>c[0]|32).Single()
Throws an exception if false, nothing if true.
Try it online!
$endgroup$
C# (Visual C# Interactive Compiler), 41 bytes
n=>n.Split().GroupBy(c=>c[0]|32).Single()
Throws an exception if false, nothing if true.
Try it online!
answered yesterday
Embodiment of IgnoranceEmbodiment of Ignorance
2,208125
2,208125
add a comment |
add a comment |
$begingroup$
Perl 6, 19 bytes
{[eq] m:g/<<./}o&lc
Try it online!
$endgroup$
add a comment |
$begingroup$
Perl 6, 19 bytes
{[eq] m:g/<<./}o&lc
Try it online!
$endgroup$
add a comment |
$begingroup$
Perl 6, 19 bytes
{[eq] m:g/<<./}o&lc
Try it online!
$endgroup$
Perl 6, 19 bytes
{[eq] m:g/<<./}o&lc
Try it online!
answered yesterday
nwellnhofnwellnhof
7,38011128
7,38011128
add a comment |
add a comment |
$begingroup$
Java, (36 bytes)
s->!s.matches("(?i)(.).* (?!\1).*")
TIO
$endgroup$
1
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string
$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
add a comment |
$begingroup$
Java, (36 bytes)
s->!s.matches("(?i)(.).* (?!\1).*")
TIO
$endgroup$
1
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string
$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
add a comment |
$begingroup$
Java, (36 bytes)
s->!s.matches("(?i)(.).* (?!\1).*")
TIO
$endgroup$
Java, (36 bytes)
s->!s.matches("(?i)(.).* (?!\1).*")
TIO
answered 23 hours ago
Nahuel FouilleulNahuel Fouilleul
2,925211
2,925211
1
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string
$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
add a comment |
1
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string
$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
1
1
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
I think the input is allowed to start with a space, and this doesn't work for input like that.
$endgroup$
– Sara J
23 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding
(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
indeed it's not a test case, but this can be handled adding
(?> *)
, using atomic group to match space at beginning and to pevent bactracking. just ` *` doesn't work because after failing matches will backtrack ` *` to match empty string$endgroup$
– Nahuel Fouilleul
14 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
$begingroup$
however reading the question again spaces can occur at the beginning beause in the example the usage is to pass the words as argument and spaces are shell argument delimiter
$endgroup$
– Nahuel Fouilleul
11 hours ago
add a comment |
1
$begingroup$
Is it intended as a
tips
question limited toPython
? If so, these both tags should be added.$endgroup$
– Arnauld
yesterday
2
$begingroup$
Heya friend! This site is usually reserved for explicitly defined problems. Things like "can the input contain punctuation" should be answered before posting, but other than that this is a great first question comparatively to the other new-user questions we usually see. Judging by your examples I'd just clarify that the only characters in the input will be "[A-Za-z ]" and your question will be purely objective. I'd scope out some other questions around here, else this may honestly be a better fit on overflow.
$endgroup$
– Magic Octopus Urn
yesterday
1
$begingroup$
What do you mean by punctuation? Which characters are included?
$endgroup$
– Embodiment of Ignorance
yesterday
1
$begingroup$
@MagicOctopusUrn Sometimes when you ask for a short solution in stackOverflow the refer to this site :)
$endgroup$
– Luis felipe De jesus Munoz
yesterday
6
$begingroup$
Welcome to PPCG! A few more test cases (including punctuation) would be a great addition to this challenge.
$endgroup$
– AdmBorkBork
yesterday