1017.A 나 누 기 B(20)

1686 단어 자바pat
이 문 제 는 A/B 를 계산 해 야 하 는데 그 중에서 A 는 1000 위 를 넘 지 않 는 정수 이 고 B 는 1 비트 의 정수 이다.출력 업 체 Q 와 나머지 R 이 필요 합 니 다.A=B*Q+R 이 성립 됩 니 다.
입력 형식:
1 줄 에 입력 하면 A 와 B 를 순서대로 주 고 중간 에 1 칸 으로 구분 합 니 다.
출력 형식:
1 줄 에서 Q 와 R 을 차례로 출력 하고 중간 은 1 칸 으로 구분 합 니 다.
입력 예시:
123456789050987654321 7

출력 예시:
17636684150141093474 3
 
 
import java.util.Scanner;

/**
 * @author jwang1 Success Factors
 */

public class Main {
  public static void main(String[] args) {

    String a;
    StringBuffer q_res = new StringBuffer();
    int b, r, q;
    Scanner cin = new Scanner(System.in);
    a = cin.next();
    b = cin.nextInt();
    int len = a.length();
    int curr = a.charAt(0) - '0';
    if (curr >= b) {
      q_res.append(curr / b);
    }
    for (int i = 1; i < len; i++) {
      q = curr % b;
      curr = q * 10 + a.charAt(i) - '0';
      q_res.append(curr / b);
    }
    q = curr % b;
    r = q;
    if (len == 1 && a.charAt(0) - '0' < b) {
      System.out.print("0 " + (a.charAt(0) - '0'));
    } else {
      System.out.print(q_res + " " + r);
    }
  }
}
// JAVA     
import java.math.BigInteger;
import java.util.Scanner;


public class Main {
    public static void main(String[] args) {
        Scanner cin = new Scanner(System.in);
        BigInteger a = cin.nextBigInteger();
        BigInteger b = cin.nextBigInteger();
        
        BigInteger q = a.divide(b);
        BigInteger r = a.mod(b);
        System.out.println(q+" "+r);
    }
}

좋은 웹페이지 즐겨찾기