- 1、本文档共28页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
(c语言题目
功能:用函数实现字符串的复制, 不允许用strcpy()函数。
?
------------------------------------------------*/
?
#include stdio.h
void? bky();
?
void copy(char str1[],char str2[])
{
? /**********Begin**********/
int i;
??? for(i=0;str1[i]!=\0;i++)
?????? str2[i]=str1[i];
??? str2[i]=\0;
?
? /**********? End? **********/
}
main()
{
? void copy();
? char c1[40],c2[40];
? gets(c1);
? copy(c1,c2);
? puts(c2);
? bky();
}
?
?
void bky()
{
? FILE *IN,*OUT;
? char i[100];
? char o[100];
? IN=fopen(in.dat,r);
? if(IN==NULL)
? {
??? printf(Read FILE Error);
? }
? OUT=fopen(out.dat,w);
? if(OUT==NULL)
? {
??? printf(Write FILE Error);
? }
? fscanf(IN,%s,i);
? copy(i,o);
? fprintf(OUT,%s\n,o);
? fclose(IN);
? fclose(OUT);
}
?
?
?
2? 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:删除字符串中所有的*号。在编写函数时,不得使用C语言提供的字符串函数。
??? 例如,字符串中的内容为:****A*BC*DEF*G*******,删除后,字符串中的内容应当是:ABCDEFG。
??? 注意:部分源程序在文件PROG1.C中。
??? 请勿改动主函数main和其它函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。*/
?
?
?
#include stdio.h
void? fun( char *a )
{
/**********? Begin? **********/
int i,j=0;
? for(i=0;a[i]!=\0;i++)
???? ? if(a[i]!=*)
???????? ? a[j++]=a[i];
? a[j]=\0;
?
??? /**********?? End? ***********/
}
main()
{? char? s[81];
?? void NONO (? );
?? printf(Enter a string:\n);gets(s);
?? fun( s );
?? printf(The string after deleted:\n);puts(s);
?? NONO();
}
?
?
?
重点题3 假定输入的字符串中只包含字母和*号。请编写函数fun,它的功能是:只删除字符串前导和尾部的*号,
串中字母之间的*号都不删除。形参n给出了字符串的长度,形参h给出了字符串中前导*号的个数,
形参e给出了字符串中最后*号的个数。在编写函数时,不得使用C语言提供的字符串函数。
??? 例如,字符串中的内容为:****A*BC*DEF*G******,删除后,字符串中的内容应当是:A*BC*DEF*G。
??? 注意:部分源程序存在文件prog.c中。
??? 请勿改动主函数main和其他函数中的任何内容,仅在函数fun的花括号中填入你编写的若干语句。*/
?
?
?
#include stdio.h
#include conio.h
void fun(char *a,int n,int h,int e)
{
?
?? ?/**********? Begin? **********/
?
? char b[81],*c,*d;
? int i=0,j=0;
? c=a;d=a;
? c=c+h;d=d+n-e-1;
? while (c=d)
? {b[i]=*c;i++;c++;}
? b[i]=\0; i=0;
? while (b[i])
? {a[j]=b[i];j++;i++;}
? a[j]=\0;
??? /**********?? End? ***********/
4功能:求出菲波那契数列的前一项与后一项之比的极限的
????? 近似值。
例如:当误差为0.0001时,函数值为0.618056。
?
-----------------------------------------------
文档评论(0)