下列给定程序中,是建立一个带头结点的单向链表,并用随机函数为各结点数据域赋值。函数fun的作用是求出单向链表结点(不包括头结点)数据域中的最大值,并且作为函数值返回。请改正程序指定部位的错误,使它能得到正确结果。 注意: 不要改动main函

admin2017-01-11  8

问题 下列给定程序中,是建立一个带头结点的单向链表,并用随机函数为各结点数据域赋值。函数fun的作用是求出单向链表结点(不包括头结点)数据域中的最大值,并且作为函数值返回。请改正程序指定部位的错误,使它能得到正确结果。
    注意:
    不要改动main函数,不得增行或删行,也不得更改程序的结构。
    【试题源程序】
    #include
    #include
    typedef struct aa,
    {
    int data;
    struct aa*next:
    }NODE;
    fun(NODE*h)
    {
    int max=-1:
    NODE*p;
    /***********found**********/
    p=h;
    while(p)
    {
    if(P->data>max)
    max=p->data:
    /***********found**********/
    p=h->next:
    }
    return max;
}
outresult(int s,FILE*pf)
{
  fprintf(pf,"\nThe max in link:%d\n",s);
}
NODE*creatlink(int n,int m)
{
    NODE*h,*p,*s,*q;
    int i,x;
    h=p=(NODE*)malloc(sizeof(NODE));
    h->data=9999:
    for(i=1;i<=n;i++)
    {
    S=(NODE*)malloc(sizeof(NODE));
    S->data=rand()%m;s->next=p->next;
    P->next=s;p=p->next;
    }
    P->next=NULL:
    return h;
}
outlink(NODE*h,FILE*pf)
{
    NODE*P;
    P=h->next:
    fprintf(pf,"\nTHE LIST:\n\nHEAD");
    while(P)
    {
    fprintf(pf,"->%d",P->data);p=p->next;
    }
    fprintf(pf,"\n");
}
main()
{
NODE*head;int m;
    head=creatlink(12,100);
    outlink(head,stdout);
    m=fun(head);
    printf("\nTHE RESULT:\n");
    outresult(m,stdout);
    }

选项

答案void fun(int *a,int *n) { int i,j=0; for(i=1;i<=1000;i++) if((i%7==0||i%11==0)&&(i%77!=0)) a[j++]=i; *n=j; }

解析 本题的设计思路是:①利用for循环,遍历1到1000之内的整数;②利用if语句判断,把能被7或11整除但不能同时被7和11整除的所有整数保存到形参数组a中;③把数组a中数组元素的个数赋值给n。
转载请注明原文地址:https://kaotiyun.com/show/IrID777K
0

相关试题推荐
最新回复(0)