백엔드/Java
알고리즘
david100gom
2024. 4. 16. 11:44
문자정렬
// 문자역순
String a = "abcd";
StringBuffer sb = new StringBuffer();
for(int i = a.length()-1 ; i >= 0; i--) {
sb.append(a.substring(i, i+1));
}
System.out.print("==>"+sb.toString());
// 자음끼리 자리교환
String[] ab = {"a","e","i","o","u"};
String input = "hello";
List<Integer> list = new ArrayList<>();
List<Integer> list2 = new ArrayList<>();
for(int i = 0 ; i < input.length(); i++) {
int b = 0;
for(int j = 0; j < ab.length; j++) {
if(!ab[j].equals(input.substring(i, i+1))) {
b++;
}
}
if(b == ab.length) {
list.add(i);
list2.add(i);
}
}
char[] t = input.toCharArray();
char[] t2 = input.toCharArray();
Collections.reverse(list);
int i = 0;
for(Integer abc : list) {
t2[list2.get(i)] = t[abc];
i++;
}
System.out.print("==>"+Arrays.toString(list.toArray()));
System.out.print("==>"+Arrays.toString(t));
System.out.print("==>"+String.valueOf(t2));
BigDecimal 비교
String[] s = new String[n];
Arrays.sort(s, Collections.reverseOrder(new Comparator<String>() {
@Override
public int compare(String a1, String a2) {
//convert to big decimal inside comparator
//so permanent string values are never changed
//aka you only use the BigDecimal values to
//compare the strings!
if(a1 == null || a2 == null) {
return 0;
}
BigDecimal a = new BigDecimal(a1);
BigDecimal b = new BigDecimal(a2);
return a.compareTo(b);
}
}));
collections.sort
import java.util.ArrayList;
import java.util.Collections;
import java.util.Comparator;
import java.util.List;
public class JavaCompareTest {
/**
* @param args
*/
public static void main(String[] args) {
// TODO Auto-generated method stub
List<User> users = getCreateUsers();
System.out.println("===== 정렬 하기전 =====");
for (User temp : users) {
System.out.println(temp);
}
Collections.sort(users, new NameAscCompare());
System.out.printf("\n\n===== 문자 오름 차순 정렬 =====\n");
for (User temp : users) {
System.out.println(temp);
}
Collections.sort(users, new NameDescCompare());
System.out.printf("\n\n===== 문자 내림 차순 정렬 =====\n");
for (User temp : users) {
System.out.println(temp);
}
Collections.sort(users, new NoAscCompare());
System.out.printf("\n\n===== 숫자 오름 차순 정렬 =====\n");
for (User temp : users) {
System.out.println(temp);
}
Collections.sort(users, new NoDescCompare());
System.out.printf("\n\n===== 숫자 내림 차순 정렬 =====\n");
for (User temp : users) {
System.out.println(temp);
}
}
/**
* User Data Create
* @return
*/
private static List<User> getCreateUsers() {
// TODO Auto-generated method stub
List<User> users = new ArrayList<User>();
User user = new User();
user.setName("고철수");
user.setAddress("경기도 성남시 분당구");
user.setPhone("010-1234-0192");
user.setNo(1);
users.add(user);
user = new User();
user.setName("박영희");
user.setAddress("부산 해운대");
user.setPhone("010-4234-0192");
user.setNo(2);
users.add(user);
user = new User();
user.setName("감수왕");
user.setAddress("충북 제천");
user.setPhone("010-7234-0192");
user.setNo(3);
users.add(user);
user = new User();
user.setName("이사람");
user.setAddress("강원도 영울");
user.setPhone("010-0234-0192");
user.setNo(4);
users.add(user);
return users;
}
/**
* 이름 오름차순
* @author falbb
*
*/
static class NameAscCompare implements Comparator<User> {
/**
* 오름차순(ASC)
*/
@Override
public int compare(User arg0, User arg1) {
// TODO Auto-generated method stub
return arg0.getName().compareTo(arg1.getName());
}
}
/**
* 이름 내림차순
* @author falbb
*
*/
static class NameDescCompare implements Comparator<User> {
/**
* 내림차순(DESC)
*/
@Override
public int compare(User arg0, User arg1) {
// TODO Auto-generated method stub
return arg1.getName().compareTo(arg0.getName());
}
}
/**
* No 오름차순
* @author falbb
*
*/
static class NoAscCompare implements Comparator<User> {
/**
* 오름차순(ASC)
*/
@Override
public int compare(User arg0, User arg1) {
// TODO Auto-generated method stub
return arg0.getNo() < arg1.getNo() ? -1 : arg0.getNo() > arg1.getNo() ? 1:0;
}
}
/**
* No 내림차순
* @author falbb
*
*/
static class NoDescCompare implements Comparator<User> {
/**
* 내림차순(DESC)
*/
@Override
public int compare(User arg0, User arg1) {
// TODO Auto-generated method stub
return arg0.getNo() > arg1.getNo() ? -1 : arg0.getNo() < arg1.getNo() ? 1:0;
}
}
}
// 문자열 비교compareTo처럼 숫자도 비교 해서 결과 값을 -1, 0, 1을 리턴 해주면 됩니다.
// -1:작다
// 0:같다
// 1:크다
깊이 우선 탐색(DFS, Depth First Search) : http://blog.eairship.kr/268
MD5, SHA-256
// MD5
public String testMD5(String str){
String MD5 = "";
try{
MessageDigest md = MessageDigest.getInstance("MD5");
md.update(str.getBytes());
byte byteData[] = md.digest();
StringBuffer sb = new StringBuffer();
for(int i = 0 ; i < byteData.length ; i++){
sb.append(Integer.toString((byteData[i]&0xff) + 0x100, 16).substring(1));
}
MD5 = sb.toString();
}catch(NoSuchAlgorithmException e){
e.printStackTrace();
MD5 = null;
}
return MD5;
}
// SHA-256
public String testSHA256(String str){
String SHA = "";
try{
MessageDigest sh = MessageDigest.getInstance("SHA-256");
sh.update(str.getBytes());
byte byteData[] = sh.digest();
StringBuffer sb = new StringBuffer();
for(int i = 0 ; i < byteData.length ; i++){
sb.append(Integer.toString((byteData[i]&0xff) + 0x100, 16).substring(1));
}
SHA = sb.toString();
}catch(NoSuchAlgorithmException e){
e.printStackTrace();
SHA = null;
}
return SHA;
}
Prime Number
void checkPrime(int... numbers) {
for (int number : numbers) {
if (BigInteger.valueOf(number).isProbablePrime(1)) {
System.out.print(number + " ");
}
}
System.out.println();
}