问答题 编写函数fun,其功能是:将两个两位数的正整数a、b合并成一个整数放在c中。合并的方式是:将a数的十位和个位数依次放在c数的十位和千位上,b数的十位和个位数依次放在c数的百位和个位上。例如,当a=45,b=12时,调用该函数后,c=5142。注意:部分源程序给出如下。数据文件IN.DAT中的数据不得修改。请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入编写的若干语句。试题程序:#include <stdlib.h>#include <stdio.h>#include <conic.h>void fun(int a,int b,long*c){}void main(){int a,b;long c;system("CLS");printf("Input a,b;");scanf("%d%d",&a,&b);fun(a,b,&c);printf("The result is:%ld\n",c);}
问答题 下列给定程序中,函数fun的功能是:求出S所指字符串中最后一次出现的t所指字符串的地址,并通过函数值返回,在主函数中输出从此地址开始的字符串;若未找到,则函数值为NULL。例如,当字符串中的内容为“abcdabfabcdx”,t中内容为“ab”时,输出结果应是“abcdx”。请改正程序中的错误,使它能得出正确的结果。注意:不要改动main函数,不得增行或删行,也不得更改程序的结构!试题程序:#include <stdlib.h>#include <stdio.h>#include <conio.h>#include <string.h>char * fun(char*s,char * t){char * p, *r, *a;/**********found**********/a=Null;while(*s){p=s;r=t;while(*r)/***********found**********/if(r==p){r++;p++;}else break;if(*r=="\0")a=s;s++;}return a;}void main(){char s[100],t[100],*p;system("CLS");printf("\nPlease enter string S:");scanf("%s",s);printf("\nPlease enter substring t:");scanf("%s",t);p=fun(s,t);if(p)printf("\nThe result is:%s\n",p);elseprintf("\nNot found!\n");}
填空题 下列给定程序中,函数fun的功能是:统计带头节点的单向链表中节点的个数,并存放在形参n所指的存储单元中。请在程序的下画线处填入正确的内容,使程序得出正确的结果。注意:部分源程序给出如下。不得增行或删行,也不得更改程序的结构!试题程序:#include <stdio.h>#include <stdlib.h>#define N 8typedef struct list{ int data;struct list * next;} SLIST;SLIST * creatlist(int *a);void outlist(SLIST*);vom fun(SLIST * h, int * n){ SLIST *p;/**********found**********/______ =0;p=h->next;while(p){ (* n)++;/**********found**********/p=p-> ______ ;}}main(){ SLIST * head;int a[N]={12,87,45,32,91,16,20,48}, num;head=creatlist(a);outlist(head);/**********found**********/fun(______, &hum);printf("\nnumber=%d\n",num);}SLIST * creatlist(int a[]){ SLIST *h,*p,*q; int i;h=p=(SLIST*)malloc(sizeof(SLIST));for(i=0;i<N;i++){ q=(SLIST*)malloc(sizeof(SLIST));q->data=a[i]; p->next=q;p=q;}p->next=0;return h;}void outlist(SLIST*h){ SLIST * p;p=h->next;if(p==NULL)printf("The list is NULL!\n");else{ printf("\nHead");do{ printf("->%d",p->data);p=p->next; }while(p! = NULL);printf("->End\n");}}