欧几里得算法,即辗转相除法
package demo2;
public class P95 {
//欧几里得算法,即辗转相除法
//一种变体是找线段上的格点数
public static void main(String[] args) {
//(1,11)和(5,3)两点间的线段
int x1=1;
int y1=11;
int x2=5;
int y2=3;
System.out.println("格点数:"+cellPoint(x1,y1,x2,y2));
}
//求|x1-x2|和|y1-y2|的gcd,也就是横纵最多都能分的段数,段数-1得格点数
static int cellPoint(int x1, int y1, int x2, int y2) {
int m=Math.abs(x1-x2);
int n=Math.abs(y1-y2);
return gcd(m, n)-1;
}
static int gcd(int m,int n) {
return n==0? m:gcd(n, m%n);
}
}
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 三行代码完成国际化适配,妙~啊~
· .NET Core 中如何实现缓存的预热?