zoukankan      html  css  js  c++  java
  • 第七次作业

    一、实验内容 

    1. 定义一个判断素数的函数isprime(int n),利用该函数输出1000以内的所有素数,每行10个,最后输出一共有多少个素数

    1.1 代码:

    #include <stdio.h>
    int isprime(int a);
    int isprime(int a)
    {
    	int b;
    	for(b=2;b<a;b++)
    	{
    		if(a%b==0)
    		return 0;
    	}
    	return b;
    }
    int main ()
    {
    	int i,j=0;
    	for(i=2;i<=1000;i++)
    	{
    		if(isprime(i))
    		{
    			printf("%4d",i);
    			j++;
    			if(j%10==0)
    			{
    				printf("
    ");
    			}
    		}
    	}
    	printf("共有%d个素数",j);
    	return 0;
    }
    

    1.2 程序运行结果:

    2.求两个正整数的最大公约数和最小公倍数。用一个函数gcd(int a,int b)求最大公约数,另一个函数lcm(int a,int b)根据求出的最大公约数求最小公倍数。

    2.1 代码:

    #include <stdio.h>
    #include <math.h>
    int lcm(int a,int b);
    int gcd(int a,int b);
    int lcm(int a,int b)
    {
    	int i;
    	i=a*b/gcd(a,b);
    	return i;
    }
    int gcd(int a,int b)
    {
    	int i,j,min;
              if(a > b)
    	{  min = b;	}
    	else
    	{  min = a;	}
    	for(i=1;i<=min;i++)
    	{
    	     if(a % i == 0 && b %i == 0)
    	      {  j = i;     }
    	}
    	return j;
    }
    int main()
    {
    	int a,b,m,n;
    	printf("请输入两个数字");
    	scanf("%d %d",&a,&b);
    	m=gcd(a,b);
    	n=lcm(a,b);
    	printf("%d和%d的最大公约数是%d,最小公倍数是%d",a,b,m,n);
    	return 0;
    }
    

    2.2 程序运行结果:

     3.编写一个函数fun(double x)求表达式x2-5x+4的值,x作为参数传给函数。在主函数中调用该函数求下列式子的值:

           y1= 22-5*2+4

           y2= (x+15)2-5*(x+15)+4

           y3= sin2x-5*sinx+4    

       求y3用数学函数 sin(x)  头文件math.h

       求解y2和y3时需要输入x的值。

       样例:

       y1=-2, x=0.5时,y2=166.75,y3=1.832721

    3.1 代码:

    #include <stdio.h>
    #include <math.h>
    double fun(double x)
    {
    	double y;
    	y=x*x-5*x+4;
    	return y;
    }
    int main()
    {
    	double x,y1,y2,y3;
    	printf("请输入一个数字");
    	scanf("%lf",&x);
    	y1=fun(2);
    	y2=fun(x+15);
    	y3=fun(sin(x));
    	printf("y1=%lf,y2=%lf,y3=%lf",y1,y2,y3);
    	return 0; 
    }
    

    3.2 程序运行结果:

    4.用函数实现:火柴棍等式问题。

    4.1 代码:

    #include <stdio.h>
    int issum(int i);
    int main()
    {
    	int a,b,c;
    	for(a=0;a<=9;a++)
    	for(b=0;b<=9;b++)
    	{
    		c=a+b;
    		if(issum(a)+issum(b)+issum(c)==12&&c<=9)
    		{
    			printf("%d+%d=%d
    ",a,b,c);
    		}
    	}
    			return 0;
    }
    int issum(int k)
    {
         int j; switch(j) {
              case 0:case 6:case 9:j=6;break; case 1:j=2;break; case 2:case 3:case 5:j=5;break; case 4:j=4;break; case 7:j=3;break; case 8:j=7;break; } return j; }

    4.2 程序运行结果:

     二、知识点总结

    1.形参和实参的运用,表示二者的字符可以相同,也可不同

    2.主函数与调用函数的应用可以使原本复杂的程序变得不再繁琐

    3.依旧需要语句嵌套,但是要括号一一对应

    4.第四题用到了穷举法,要多理解穷举法

    三、实验总结

    1.最小公倍数的符号是lcm,而不是lim

    2.调用函数时要将定义的符号再写一次,而且开始时就要定义好

    3.case语句遇见相同的结果时,合并时用“:”而不是“;”

    4.sinX应用时要再加一层括号。

  • 相关阅读:
    RedHat中代理设置
    CentOS7主机名修改
    ELK+Filebeat+Kafka+ZooKeeper 构建海量日志分析平台
    Zookeeper+Kafka集群部署
    Centos7 中lvs DR配置
    linux抓包命令之tcpdump
    python调用ansible接口API执行命令
    LVS 实现负载均衡原理及安装配置详解
    Ansible 之Playbook
    Linux系统date时间设定
  • 原文地址:https://www.cnblogs.com/wei530/p/6083415.html
Copyright © 2011-2022 走看看