作业七

C语言函数应用实例
本文通过四个具体的C语言编程案例,介绍了如何定义和使用函数来解决实际问题,包括素数判断、最大公约数与最小公倍数计算、数学表达式求值及火柴棍等式问题。

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

#include<stdio.h>
# include <stdlib.h>
# include <math.h>
int isprime(int n);
int isprime(int n)
{
         int i1,i2,x,flag;
         flag=0;
        x=sqrt(n);
            flag=0;
            for(i2=2;i2<=x;i2++)
            {
                if(n%i2==0)
                {
                    flag=1;
                    break;
                }
            } 
             if(flag==1)
            {
                n=1;
            }
        return n;
}
int main()
{
    int i,y,m=0;
    for(i=2;i<=1000;i++)
    {
        y=isprime(i);
        if(y!=1)
        {
            printf("%03d ",y);
            m++;
            if(m!=0&&m%10==0)
            {
                 printf("\n");
            }
        }    
    }
    printf(" \n有%d个素数",m);
    return 0;
}

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

#include<stdio.h>
int gcd(int a,int b); 
int lcm(int a,int b);
int main()
{
    int a1,b1,a2,b2;
    tt:printf("输入两个正整数,用逗号隔开\n");
    scanf("%d,%d",&a2,&b2); 
    if(a2<0||b2<0)
    {
        printf("输入错误\n");
        goto tt;
    }
    a1=gcd(a2,b2);
    b1=lcm(a2,b2);
    printf("%d,%d的最大公约数是%d,最小公倍数是%d\n",a2,b2,a1,b1);
    return 0;        
}
int gcd(int a,int b)
{
    int i,c;
     if(a<b)
    {
        c=a;
    }
    else
    {
        c=b;
    }
    for(i=b;i>0;i--)
    {
         if(b%i==0&&a%i==0)
        {
            break;
        }
    }
    return i;
}
int lcm(int a,int b)
{
    int i1;
    i1=a*b/gcd(a,b);
    return i1;
}

 

 

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的值。

#include<stdio.h>
#include<math.h>
double fun(double x);
double fun(double x)
{
    double y;
    y=x*x-5*x+4;
    return y; 
}
    int main()
{
    double  x,y1,y2,y3;
    printf("函数为y=x*x-5*x+4\n 请输入x的值:\n");
    scanf("%lf",&x);
    y1=fun(x);
    y2=fun(x+15);
    y3=fun(sin(x));
    printf("%.4lf  %.4lf  %.4lf",y1,y2,y3);
}

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

#include<stdio.h>
int mty(int a);
int main()
{    
    int x,y,sum;
    for(x=0;x<=9;x++)
    for(y=0;y<=9;y++)
    {
        sum=x+y;
    if((mty(x)+mty(y)+mty(sum)==12)&&x<9&&y<9&&sum<9)
          {
              printf("%d+%d=%d\n",x,y,sum);
          }
    }
        return 0;
}
int mty(int z)
{
    int gen3;
    switch(z)
           {
           case 0: gen3=6; break;
           case 1: gen3=2; break;
           case 2: gen3=5; break;
           case 3: gen3=5; break;
           case 4: gen3=4; break;
           case 5: gen3=5; break;
           case 6: gen3=6; break;
           case 7: gen3=3; break;
           case 8: gen3=7; break;
           case 9: gen3=6; break;
               }
               return gen3;
}

附加题:

# include <stdio.h>
# include <stdlib.h>
# include <math.h>
int isValidate(int year,int month); /*合法性*/
int isLeap(int year);                /*判断闰年*/
int days(int year,int month);        /*某年某月天数*/
int totalDays(int year,int month);    /*总天数*/
void printCanlender(int year,int month);/*输出*/
int main()
{
    int a,year,month;
    A:printf("请输入日期年月用逗号隔开:\n");
    scanf("%d %d",&year,&month);
    a=isValidate(year,month);/*合法性*/        /*调用函数1*/
    if(a==0)
    {
        printf("输入错误!!!");
        goto A;
    }
    printCanlender(year,month);
return 0;    
}
void printCanlender(int year,int month)
{
    int a,b,c,i,x1=0,f,x;
    a=totalDays(year,month)    ;    /*调用函数4*/
    c=days(year,month);            /*调用函数3*/
    b=a%7;
    printf("%d年%d月\n",year,month);
    printf("星期日\t星期一\t星期二\t星期三\t星期四\t星期五\t星期六\n");
    for(i=0;i<b;i++)
    {
        printf("\t");
        x1++;
    }
    for(i=1;i<=c;i++)
    {
        printf("%-2d\t",i);
        x1++;
        if(x1!=0&&x1%7==0)
        {
            printf("\n");
        }
    }
    
}
int isValidate(int year,int month)        /*函数1*/
{
    int a=1;
    if(year<1900||month<1||month>12)
    {
        a=0;
    }
return a;
}

int isLeap(int year)                            /*判断闰年*/    /*函数2*/
{
    int a=1;
    if((year%4==0&&year%100!=0)||year%400==0)
    {
        a=0;
    }
return a;
}

int days(int year,int month)                    /*某年某月的天数*/    /*函数3*/
{
    int a,b;
    a=isLeap(year);
    if(month==1||month==3||month==5||month==7||month==8||month==10||month==12)
    {
        b=31;
    }
    else if(month==4||month==6||month==9||month==11)
    {
        b=30;
    }
    else
    {
        if(a==0)
        {
            b=29;
        }
        else
        {
            b=28;
        }        
    }
return b;    
}

int totalDays(int year,int month)                /*总天数*/        /*函数4*/
{
    int day,i,j;
    day=0;
    for(i=1900;i<=year;i++)
    {
        for(j=1;j<month;j++)
        {
            day=day+days(i,j);
        }
    }
return day;    
}

 

二、知识点总结:

1.注意函数的调用。

2.分清各个函数对应的关系。

3.函数也是一段程序,可以对多个数值进行计算,注意括号里的变量。

4.函数结束,要用return,使函数有出口。

5.最前边函数后边要加“;”,程序中后边不加“;”。

6.注意 # include <stdlib.h> 和# include <math.h>的使用。

三、实验总结:

1.不给变量初值的话可能造成结果错误。

2.火柴实验,注意区分数字和根数的加法运算和联系。

3.注意公约数和公倍数的求法。

转载于:https://www.cnblogs.com/mty1997/p/6067011.html

内容概要:本文系统介绍了算术优化算法(AOA)的基本原理、核心思想及Python实现方法,并通过图像分割的实际案例展示了其应用价值。AOA是一种基于种群的元启发式算法,其核心思想来源于四则运算,利用乘除运算进行全局勘探,加减运算进行局部开发,通过数学优化器加速函数(MOA)和数学优化概率(MOP)动态控制搜索过程,在全局探索与局部开发之间实现平衡。文章详细解析了算法的初始化、勘探与开发阶段的更新策略,并提供了完整的Python代码实现,结合Rastrigin函数进行测试验证。进一步地,以Flask框架搭建前后端分离系统,将AOA应用于图像分割任务,展示了其在实际工程中的可行性与高效性。最后,通过收敛速度、寻优精度等指标评估算法性能,并提出自适应参数调整、模型优化和并行计算等改进策略。; 适合人群:具备一定Python编程基础和优化算法基础知识的高校学生、科研人员及工程技术人员,尤其适合从事人工智能、图像处理、智能优化等领域的从业者;; 使用场景及目标:①理解元启发式算法的设计思想与实现机制;②掌握AOA在函数优化、图像分割等实际问题中的建模与求解方法;③学习如何将优化算法集成到Web系统中实现工程化应用;④为算法性能评估与改进提供实践参考; 阅读建议:建议读者结合代码逐行调试,深入理解算法流程中MOA与MOP的作用机制,尝试在不同测试函数上运行算法以观察性能差异,并可进一步扩展图像分割模块,引入更复杂的预处理或后处理技术以提升分割效果。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值