Лучший способ создать массив всех букв в алфавите
Щас делаю
for (char c = 'a'; c <= 'z'; c++) {
alphabet[c - 'a'] = c;
}
но есть ли лучший способ сделать это? Похож на Скала 'a' to 'z'
21 ответ
Я думаю, что это немного чище, вам не нужно иметь дело с вычитанием и индексацией:
char[] alphabet = "abcdefghijklmnopqrstuvwxyz".toCharArray();
char[] alphabet = {'a','b','c','d','e','f','g','h','i','j','k','l','m','n','o','p','q','r','s','t','u','v','w','x','y','z'};
Определите любые языки перечисления и вызовите getAlphabet();
char[] armenianAlphabet = getAlphabet(LocaleLanguage.ARMENIAN);
char[] russianAlphabet = getAlphabet(LocaleLanguage.RUSSIAN);
// get uppercase alphabet
char[] currentAlphabet = getAlphabet(true);
System.out.println(armenianAlphabet);
System.out.println(russianAlphabet);
System.out.println(currentAlphabet);
результат
I / System.out: աբգդեզէըթժիլխծկհձղճմյնշոչպջռսվտրցւփքօֆ
I / System.out: абвгдежзийклмнопрстуфхцчшщъыьэюя
I / System.out: ABCDEFGHIJKLMNOPQRSTUVWXYZ
private char[] getAlphabet(){
return getAlphabet(false);
}
private char[] getAlphabet(boolean flagToUpperCase){
Locale locale = getResources().getConfiguration().locale;
LocaleLanguage language = LocaleLanguage.getLocalLanguage(locale);
return getAlphabet(language, flagToUpperCase);
}
private char[] getAlphabet(LocaleLanguage localeLanguage, boolean flagToUpperCase){
if (localeLanguage == null)
localeLanguage = LocaleLanguage.ENGLISH;
char firstLetter = localeLanguage.getFirstLetter();
char lastLetter = localeLanguage.getLastLetter();
int alphabetSize = lastLetter - firstLetter + 1;
char[] alphabet = new char[alphabetSize];
for (int index = 0; index < alphabetSize; index++ ){
alphabet[index] = (char) (index + firstLetter);
}
if (flagToUpperCase){
alphabet = new String(alphabet).toUpperCase().toCharArray();
}
return alphabet;
}
private enum LocaleLanguage{
ARMENIAN(new Locale("hy"), 'ա', 'ֆ'),
RUSSIAN(new Locale("ru"), 'а','я'),
ENGLISH(new Locale("en"), 'a','z');
private final Locale mLocale;
private final char mFirstLetter;
private final char mLastLetter;
LocaleLanguage(Locale locale, char firstLetter, char lastLetter) {
this.mLocale = locale;
this.mFirstLetter = firstLetter;
this.mLastLetter = lastLetter;
}
public Locale getLocale() {
return mLocale;
}
public char getFirstLetter() {
return mFirstLetter;
}
public char getLastLetter() {
return mLastLetter;
}
public String getDisplayLanguage(){
return getLocale().getDisplayLanguage();
}
public String getDisplayLanguage(LocaleLanguage locale){
return getLocale().getDisplayLanguage(locale.getLocale());
}
@Nullable
public static LocaleLanguage getLocalLanguage(Locale locale){
if (locale == null)
return LocaleLanguage.ENGLISH;
for (LocaleLanguage localeLanguage : LocaleLanguage.values()){
if (localeLanguage.getLocale().getLanguage().equals(locale.getLanguage()))
return localeLanguage;
}
return null;
}
}
Это забавное решение Unicode.
char[] alpha = new char[26]
for(int i = 0; i < 26; i++){
alpha[i] = (char)(97 + i)
}
Это создает версию алфавита в нижнем регистре, если вы хотите использовать верхний регистр, вы можете заменить "97" на "65".
Надеюсь это поможет.
В Java 8 с Stream API вы можете сделать это.
IntStream.rangeClosed('A', 'Z').mapToObj(var -> (char) var).forEach(System.out::println);
Если вы используете Java 8
char[] charArray = IntStream.rangeClosed('A', 'Z')
.mapToObj(c -> "" + (char) c).collect(Collectors.joining()).toCharArray();
static String[] AD = {"0", "1", "2", "3", "4", "5", "6", "7", "8", "9", "A", "B", "C", "D", "E", "F", "G", "H", "I", "G", "K", "L", "M", "N", "O", "P", "Q", "R", "S", "T", "U", "V", "W", "X", "Y", "Z", "a", "b", "c", "d", "e", "f", "g", "h", "i", "j", "k", "l", "m", "n", "o", "p", "q", "r", "s", "t", "u", "v", "w", "x", "y", "z"};//Alphabet&Digit
С io.vavr
public static char[] alphanumericAlphabet() {
return CharSeq
.rangeClosed('0','9')
.appendAll(CharSeq.rangeClosed('a','z'))
.appendAll(CharSeq.rangeClosed('A','Z'))
.toCharArray();
}
Проверьте это, как только я уверен, что вы получите a
в z
алфавиты:
for (char c = 'a'; c <= 'z'; c++) {
al.add(c);
}
System.out.println(al);'
Вот несколько альтернатив, основанных на ответе тома томаса.
Массив символов:
char[] list = IntStream.concat(
IntStream.rangeClosed('0', '9'),
IntStream.rangeClosed('A', 'Z')
).mapToObj(c -> (char) c+"").collect(Collectors.joining()).toCharArray();
Строковый массив:
Примечание: не будет работать правильно, если ваш разделитель также является одним из значений.
String[] list = IntStream.concat(
IntStream.rangeClosed('0', '9'),
IntStream.rangeClosed('A', 'Z')
).mapToObj(c -> (char) c+",").collect(Collectors.joining()).split(",");
Список строк:
Примечание: не будет работать правильно, если ваш разделитель также является одним из значений.
List<String> list = Arrays.asList(IntStream.concat(
IntStream.rangeClosed('0', '9'),
IntStream.rangeClosed('A', 'Z')
).mapToObj(c -> (char) c+",").collect(Collectors.joining()).split(","));
Для разработчиков Android, которые ищут решение для Kotlin и попадают сюда:
// List<Char>
val chars1 = ('a'..'z').toList()
// Array<Char> (boxed)
val chars2 = ('a'..'z').toList().toTypedArray()
// CharArray (unboxed)
val chars3 = CharArray(26) { 'a' + it }
// CharArray (unboxed)
val chars4 = ('a'..'z').toArray()
fun CharRange.toArray() = CharArray(count()) { 'a' + it }
Чтобы понять, что я имею в виду под "упакованными" и "распакованными", см. Этот пост .
Благодаря этой ветке .
Простота - это достоинство. Используйте этот естественно читаемый массив:
char alphabet[] = {'a', 'b', 'c', 'd', 'e', 'f', 'g', 'h', 'i', 'j', 'k', 'l', 'm', 'n', 'o', 'p', 'q', 'r', 's', 't', 'u', 'v', 'w', 'x', 'y', 'z'};
char[] abc = new char[26];
for(int i = 0; i<26;i++) {
abc[i] = (char)('a'+i);
}
const alphabetArray = "abcdefghijklmnopqrstuvwxyz".split("");
Использование потоков Java 8
char [] alphabets = Stream.iterate('a' , x -> (char)(x + 1))
.limit(26)
.map(c -> c.toString())
.reduce("", (u , v) -> u + v).toCharArray();
var alphabet = IntStream.rangeClosed('a', 'z')
.boxed()
.map(Character::toChars)
.map(String::valueOf)
.toList();
Примечания
-
rangeClosed()
чтобы сделать это'z'
включительно -
boxed()
для создания списка изIntStream
-
toList()
создает неизменяемый список, но, по-видимому, доступен только начиная с Java 16
Чтобы получить прописные буквы в дополнение к строчным, вы также можете сделать следующее:
String alphabetWithUpper = "abcdefghijklmnopqrstuvwxyz" + "abcdefghijklmnopqrstuvwxyz".toUpperCase();
char[] letters = alphabetWithUpper.toCharArray();
В котлине вы можете это сделать
var alphabet = "abcdefghijklmnopqrstuvwxyz".toCharArray()
import java.util.*;
public class Experiments{
List uptoChar(int i){
char c='a';
List list = new LinkedList();
for(;;) {
list.add(c);
if(list.size()==i){
break;
}
c++;
}
return list;
}
public static void main (String [] args) {
Experiments experiments = new Experiments();
System.out.println(experiments.uptoChar(26));
}
Наконец вы получаете char
array
с алфавитом. Почему вы сделали так сложно, используя loop
?
Просто
char[] alphabet=new char[]{'a','b',.........,'z'}
for (char letter = 'a'; letter <= 'z'; letter++)
{
System.out.println(letter);
}