⑴ c語言編程:輸入兩個正整數,求最大公約數和最小公倍數
#include
voidmain(){
inta,b,n1,n2,t;
while(true)
{
printf("任意輸入兩個正整數: ");
scanf("%d%d",&n1,&n2);
if(n1
{
t=n1;
n1=n2;
n2=t;
}
a=n1;
b=n2;
while(b!=0){/*利用輾除法,直到b為0為止*/
t=a%b;
a=b;
b=t;
}
printf("最大公約數為:%d ",a);
printf("最小公倍數為:%d ",n1*n2/a);
}}
(1)程序編譯最大公約數擴展閱讀
C語言求最大公約數輾轉相除法
#include<stdio.h>
intgcd(intm,intn);//將輾轉相除的過程封裝為函數,使主函數結構清晰。
intmain(void)
{
inta,b;
while(~scanf("%d%d",&a,&b)){//多組數據輸入時的方式之一與while(scanf("%d%d",&a,&b)!=EOF)用途相同
printf("%d ",gcd(a,b));
return0;
}
intgcd(intm,intn)
{
returnn?gcd(n,m%n):m;//此函數將輾轉相除的過程以遞歸的形式呈現,簡化程序屬於常規套路。
}
⑵ 編寫一段代碼使用C語言嵌人匯編程序,在匯編程序中實現求兩個數的最大公約數
在C語言中嵌入匯編代碼可以使用`asm`關鍵字,具體的實現方式取決於所使用的編譯器和平台。下面是一個簡單的示例代碼,使用C語言嵌入匯編程序來求兩個數的最大公約數:
```c
#include <stdio.h>
int gcd(int a, int b) {
int result;
asm volatile(
"mov %1, %%eax\n" // 將a的值放入eax寄存器
"mov %2, %%ebx\n" // 將b的值放入ebx寄存器
"cmp $0, %%ebx\n" // 將b與0比較
"je end\n" // 如果b等於0,跳轉到end標簽
"gcd_loop:\n" // 定義gcd_loop標簽
"mov %%ebx, %%edx\n" // 將ebx的值放入edx寄存器
"mov $0, %%ebx\n" // 將0放入ebx寄存器
"idiv %%edx\n" // edx:eax除以edx,結果保存在eax,余數保存在edx
"mov %%edx, %%eax\n" // 將edx的值放入eax寄存器
"cmp $0, %%eax\n" // 將eax與0比較
"jne gcd_loop\n" // 如果eax不等於0,跳轉到gcd_loop標簽
"mov %%edx, %0\n" // 將edx的值保存到result變數中
"end:\n" // 定義end標簽
: "=r" (result) // 輸出寄存器,將結果保存到result變數中
: "r" (a), "r" (b) // 輸入寄存器,將a和b的值傳入匯編代碼
: "eax", "ebx", "edx" // 被修改的寄存器
);
return result;
}
int main() {
int a, b;
printf("請輸入兩個整數:");
scanf("%d %d", &a, &b);
int result = gcd(a, b);
printf("最大公約數為:%d\n", result);
return 0;
}
```
在上面的代碼中,匯編部分通過使用寄存器來進行數值的操作和判斷,求得最大公約數後,將結果保存在C語言的變數`result`中,並返回給調用函數。請注意,這只是一個簡單示例,實際使用時需要根據編譯器和平台的不同進行適當的調整。