#include <stdio.h>int main(){ int hcf(int x, int y); int lcd(int x, int y); int a, b, c, d; printf("请输入两个数:"); scanf_s("%d%d", &a, &b); c = hcf(a, b); d = lcd(a, b); printf("最大公约数:%d\n最小公倍数:%d\n", c, d); return 0;}int hcf(int x, int y){ int i, z; if (x < y) { i = x; x = y; y = i; } z = x % y; while (z) { x = y; y = z; } return (z);}int lcd(int x, int y){ int i, z, m, n; m = x * y; if (x < y) { i = x; x = y; y = i; } z = x % y; while (z) { x = y; y = z; } n = m / z; return (n);}
2条回答 默认 最新
- 技术专家团-Bamboo 2021-11-21 13:57关注
看走眼了,while循环出不来,z的值一直没有变化,要更新z的值,最后return的是y的值,辗转相除法
#include <stdio.h> int main() { int hcf(int x, int y); int lcd(int x, int y); int a, b, c, d; printf("请输入两个数:"); scanf("%d%d", &a, &b); c = hcf(a, b); d = lcd(a, b); printf("最大公约数:%d\n最小公倍数:%d\n", c, d); return 0; } int hcf(int x, int y) { int i, z; if (x < y) { i = x; x = y; y = i; } z = x % y; while (z) { x = y; y = z; z = x % y; } return (y); } int lcd(int x, int y) { int i, z, m, n; m = x * y; if (x < y) { i = x; x = y; y = i; } z = x % y; while (z) { x = y; y = z; z = x % y; } n = m / y; return (n); }
本回答被题主选为最佳回答 , 对您是否有帮助呢?解决 无用评论 打赏 举报 编辑记录
悬赏问题
- ¥20 Keil uVision5创建project没反应
- ¥15 mmseqs内存报错
- ¥15 vika文档如何与obsidian同步
- ¥15 华为手机相册里面的照片能够替换成自己想要的照片吗?
- ¥15 陆空双模式无人机飞控设置
- ¥15 sentaurus lithography
- ¥100 求抖音ck号 或者提ck教程
- ¥15 关于#linux#的问题:子进程1等待子进程A、B退出后退出(语言-c语言)
- ¥20 web页面如何打开Outlook 365的全球离线通讯簿功能
- ¥15 io.jsonwebtoken.security.Keys