Here you can find the source of gcd(long x, long y)
public static long gcd(long x, long y)
//package com.java2s; /*/*from w w w . j av a2 s . co m*/ * Copyright (C) 2015 Dell, Inc. * * Licensed under the Apache License, Version 2.0 (the "License"); * you may not use this file except in compliance with the License. * You may obtain a copy of the License at * * http://www.apache.org/licenses/LICENSE-2.0 * * Unless required by applicable law or agreed to in writing, software * distributed under the License is distributed on an "AS IS" BASIS, * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. * See the License for the specific language governing permissions and * limitations under the License. */ public class Main { public static long gcd(long x, long y) { if (x < 0) x = -x; if (y < 0) y = -y; if (x < y) { long temp = x; x = y; y = temp; } long gcd = 1; while (y > 1) { if ((x & 1) == 0) { if ((y & 1) == 0) { gcd <<= 1; x >>= 1; y >>= 1; } else { x >>= 1; } } else { if ((y & 1) == 0) { y >>= 1; } else { x = (x - y) >> 1; } } if (x < y) { long temp = x; x = y; y = temp; } } return y == 1 ? gcd : gcd * x; } }