A股上市公司传智教育(股票代码 003032)旗下技术交流社区北京昌平校区

 找回密码
 加入黑马

QQ登录

只需一步,快速开始

© IOS菜鸟! 初级黑马   /  2016-5-15 00:28  /  1296 人查看  /  0 人回复  /   0 人收藏 转载请遵从CC协议 禁止商业使用本文

【程序14】

题目:将一个正整数分解质因数。例如:输入90,打印出90=2*3*3*5。

程序分析:对n进行分解质因数,应先找到一个最小的质数k,然后按下述步骤完成:

(1)如果这个质数恰等于n,则说明分解质因数的过程已经结束,打印出即可。

(2)如果n<>k,但n能被k整除,则应打印出k的值,并用n除以k的商,作为新的正整数你n,

 重复执行第一步。

(3)如果n不能被k整除,则用k+1作为k的值,重复执行第一步。

2.程序源代码:

main()

{

int n,i;

printf("\nplease input a number:\n");

scanf("%d",&n);

printf("%d=",n);

for(i=2;i<=n;i++)

 {

  while(n!=i)

  {

   if(n%i==0)

   { printf("%d*",i);

    n=n/i;

   }

   else

    break;

  }

}

printf("%d",n);}

==============================================================

【程序15】

题目:利用条件运算符的嵌套来完成此题:学习成绩>=90分的同学用a表示,60-89分之间的用b表示,

   60分以下的用c表示。

1.程序分析:(a>b)?a:b这是条件运算符的基本例子。

2.程序源代码:

main()

{

 int score;

 char grade;

 printf("please input a score\n");

 scanf("%d",&score);

 grade=score>=90?'a':(score>=60?'b':'c');

 printf("%d belongs to %c",score,grade);

}

==============================================================

【程序16】

题目:输入两个正整数m和n,求其最大公约数和最小公倍数。

1.程序分析:利用辗除法。

2.程序源代码:

main()

{

 int a,b,num1,num2,temp;

 printf("please input two numbers:\n");

 scanf("%d,%d",&num1,&num2);

 if(num1 { temp=num1;

  num1=num2; 

  num2=temp;

 }

a=num1;b=num2;

while(b!=0)

 {

  temp=a%b;

  a=b;

  b=temp;

 }

printf("gongyueshu:%d\n",a);

printf("gongbeishu:%d\n",num1*num2/a);

}

==============================================================



0 个回复

您需要登录后才可以回帖 登录 | 加入黑马