Dash Insert

DashInsert 함수는 숫자로 구성된 문자열을 입력받은 뒤, 문자열 내에서 홀수가 연속되면 두 수 사이에 - 를 추가하고, 짝수가 연속되면 * 를 추가하는 기능을 갖고 있다. (예, 454 => 454, 4546793 => 454*67-9-3) DashInsert 함수를 완성하자. 출처

  • 입력 - 화면에서 숫자로 된 문자열을 입력받는다.
"4546793"
  • 출력 - *, -가 적절히 추가된 문자열을 화면에 출력한다.
"454*67-9-3"
※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.

6개의 풀이가 있습니다.

Java

import java.util.function.UnaryOperator;

public class DashInsert {
    public static UnaryOperator<Integer> oddOrEven = i -> i % 2 == 0 ? 1:-1;
    public static UnaryOperator<String> dashInsert = s -> {
        int beforeState = 0;
        int currentState = 0;
        String result = "";
        for (int i = 0; i < s.length(); i++) {
            currentState = oddOrEven.apply(Character.getNumericValue(s.charAt(i)));
            if (currentState == beforeState) {
                if (currentState == 1) {
                    result += "*";
                } else {
                    result += "-";
                }
            }
            beforeState = currentState;
            result += Character.toString(s.charAt(i));
        }
        return result;
    };
    public static void main(String[] args) {
        System.out.println(dashInsert.apply("112234566778"));
    }
}
  • 결과 : 1-12*23456*67-78
※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.

public class Main {
    public static void main(String[] args) {
        String str = args[0];
        DashInsert dashInsert = new DashInsert();
        StringBuffer result = dashInsert.dashInsert(str);

        System.out.print(result);
    }
}

public class DashInsert {

    public StringBuffer dashInsert(String str) {
        StringBuffer newStr = new StringBuffer();
        String temp = str;
        int p = -1;
        int q = -1;
        newStr.append(""+temp.charAt(0));
        for(int i=1; i<temp.length(); i++) {
            p = Integer.parseInt(""+temp.charAt(i-1));
            q = Integer.parseInt(""+temp.charAt(i));

            if((p%2==0)&&(q%2==0))
                newStr.append("*"+q);
            else if((p%2!=0)&&(q%2!=0))
                newStr.append("-"+q);
            else
                newStr.append(""+q);
        }
        return newStr;
    }
}

※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.
package codingdojang;

public class DashInsert
{
    enum NUM
    {
        EVEN,
        ODD,
        NOT
    }

    private static String dashInsert(String num)
    {
        StringBuffer result = new StringBuffer();

        for ( int i = 0; i < num.length() - 1; i++ )
        {
            int firstDigit = Integer.parseInt( num.charAt( i ) + "" );
            int secondDigit = Integer.parseInt( num.charAt( i + 1 ) + "" );

            result.append( firstDigit );

            switch ( isInsertDash( firstDigit, secondDigit) )
            {
            case EVEN:
                result.append( "*" );
                break;
            case ODD:
                result.append( "-" );
                break;
            default:
                break;
            }
        }

        result.append( num.charAt( num.length()-1 ) );

        return result.toString();
    }

    private static NUM isInsertDash( int firstDigit, int secondDigit )
    {
        if ( isEven( firstDigit ) && isEven( secondDigit ) )
        {
            return NUM.EVEN;
        }
        else if ( !isEven( firstDigit) && !isEven( secondDigit ))
        {
            return NUM.ODD;
        }
        else
        {
            return NUM.NOT;
        }

    }

    private static boolean isEven( int firstDigit )
    {
        return firstDigit % 2 == 0;
    }

    public static void main( String[] args )
    {
        String num = "4546793";
        String result = dashInsert( num );
        System.out.println( result );
    }
}

※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.

왕초보가 만든 자바풀이(믿거나 말거나#2) 푸는데 5시간걸림 ㅠ.ㅠ <풀이> 1. 입력받은 숫자를 문자열 배열로 2. 문자열은 홀수/짝수 확인이 안됨으로 문자열 배열은 정수 배열로 변환 3. 정수 배열은 값에 대한 수정이 안됨으로 List로 바꿈 4. 홀수 혹은 짝수 사이에 임의의 두 수(-부호)를 첨가함. 5. 임의의 수를 와 -로 변경해야하는데 정수List라 안되서 단지 문자열 List로 전환 6. 변경된 문자열 List에서 임의의 두 수를 찾아 와 -로 변경한 후 출력함

        public static void main(String[] args) {
        Scanner sc=new Scanner(System.in);
        System.out.print("일련된 정수를 임의대로 공백없이 나열하시오. ");
        List<String> list=Arrays.asList(sc.nextLine().split(""));
        List<Integer> intList=new ArrayList<Integer>();
        for(String s : list) 
            intList.add(Integer.valueOf(s));
        for(int i=1;i<=list.size()+1;i++) {
            if(intList.get(i-1)%2==0&&intList.get(i)%2==0)
                intList.add(i,-1);
            if(intList.get(i-1)%2==1&&intList.get(i)%2==1)
                intList.add(i,-2);
        }
        List<String> strList=new ArrayList<String>();
        for(int s : intList)
            strList.add(String.valueOf(s));

        for(int i=0;i<strList.size();i++) {
            if(strList.contains("-1"))
                strList.set(strList.indexOf("-1"),"*");
            if(strList.contains("-2"))
                strList.set(strList.indexOf("-2"),"-");
        }

        for(int i=0;i<strList.size();i++)
            System.out.print(strList.get(i));
        sc.close();
    }

코드의 문제점 : *는 5번, -는 4번이상 안찍임.. 예1) 8888888888 = 8*8*8*8*8*88888 예2) 7777777777 = 7-7-7-7-777777

※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.
public static void main(String[] args){
        String dashString = "4546793";
        boolean isSame = false;
        String newDashString = "";

        for(int i = 0; i < dashString.length() - 1; i++){
            char char1 = dashString.charAt(i);
            char char2 = dashString.charAt(i + 1);

            if(Integer.parseInt(Character.toString(char1)) % 2 == 0 && Integer.parseInt(Character.toString(char2)) % 2 == 0) {
                newDashString += Character.toString(char1) + "*";
            }
            else if(Integer.parseInt(Character.toString(char1)) % 2 != 0 && Integer.parseInt(Character.toString(char2)) % 2 != 0){
                newDashString += Character.toString(char1) + "-";
            }
            else {
                newDashString += Character.toString(char1);
            }

            if(i == dashString.length() - 2) {
                newDashString += Character.toString(char2);
            }
        }
        System.out.println(newDashString);

    }
※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.
import java.util.Scanner;

public class dashinsert {
    public static void main(String[] args) {
        Scanner sc = new Scanner(System.in);

        System.out.print("숫자를 입력하세요 : ");
        String num = sc.nextLine();

        char[] ch = num.toCharArray();
        String result = "";

        for(int i = 0; i < ch.length-1; i++){
            if( ch[i]%2 == 1 && ch[i+1]%2 == 1 ){
                result += ch[i] + "-";
            } else if (ch[i]%2 == 0 && ch[i+1]%2 == 0){
                result += ch[i] + "*";
            } else {
                result += ch[i];
            }
        }
        result += ch[ch.length-1];

        System.out.println("최종결과는 " + result + " 입니다.");
    }
}

※ 상대에게 상처를 주기보다 서로에게 도움이 될 수 있는 댓글을 달아 주세요.

풀이 작성

※ 풀이작성 안내
  • 본문에 코드를 삽입할 경우 에디터 우측 상단의 "코드삽입" 버튼을 이용 해 주세요.
  • 마크다운 문법으로 본문을 작성 해 주세요.
  • 풀이를 읽는 사람들을 위하여 풀이에 대한 설명도 부탁드려요. (아이디어나 사용한 알고리즘 또는 참고한 자료등)
  • 작성한 풀이는 다른 사람(빨간띠 이상)에 의해서 내용이 개선될 수 있습니다.
목록으로
코딩도장

코딩도장은 프로그래밍 문제풀이를 통해서 코딩 실력을 수련(Practice)하는 곳입니다.


언어별 풀이 현황
전 체 x 25
java x 6
python x 10
javascript x 2
기 타 x 3
cpp x 2
php x 1
ruby x 1