发布时间 : 星期四 文章C语言必背个经典程序更新完毕开始阅读f57168835dbfc77da26925c52cc58bd6318693b5
fprintf(fp,“\\n%s”,str); fclose(fp); }
9、/*下面程序的功能是从字符数组s中删除存放在c中的字符。*/ #include
{ char s[80],c; int j,k;
printf(\ gets(s);
printf(\ c=getchar( );
for(j=k=0;s[j]!= '\\0';j++) if(s[j]!=c) s[k++]=s[j]; s[k]= '\\0';
printf(\}
10、/*编写一个void sort(int *x,int n)实现将x数组中的n个数据从大到小
排序。n及数组元素在主函数中输入。将结果显示在屏幕上并输出到文件p9_1.out中*/ #include
void sort(int *x,int n) {
int i,j,k,t;
for(i=0;i for(j=i+1;j t=x[i]; x[i]=x[k]; x[k]=t; } } } void main() {FILE *fp; int *p,i,a[10]; fp=fopen(\ p=a; printf(\for(i=0;i<10;i++) scanf(\p=a; sort(p,10); for(;p { printf(\ fprintf(fp,\ system(\ fclose(fp); } 11、已知数组a中的元素已按由小到大顺序排列,以下程序的功能是将输入的一个数插入数组a中,插入后,数组a中的元素仍然由小到大顺序排列*/ main() { int a[10]={0,12,17,20,25,28,30}; /*a[0]为工作单元,从a[1]开始存放数据*/ int x , i, j=6; /*j为元素个数*/ printf(\ scanf(\ a[0]=x; i=j; /*从最后一个单元开始*/ while(a[i]>x) { a[i+1]=a[i]; i--; } /*将比x大的数往后移动一个位置*/ a[++i]=x; j++; /*插入x后元素总个数增加*/ for(i=1;i<=j;i++) printf(\ printf(\ } 12、/*编写函数replace(char *s,char c1,char c2)实现将s所指向的字符串中所有字符c1用c2替换,字符串、字符c1和c2均在主函数中输入,将原始字符串和替换后的字符串显示在屏幕上,并输出到文件p10_2.out中*/ #include replace(char *s,char c1,char c2) { while(*s!='\\0') { if (*s==c1) *s=c2; s++; } } main() { FILE *fp; char str[100],a,b; if((fp=fopen(\ { printf(\ exit(0); } printf(\ gets(str); printf(\ scanf(\printf(\fprintf(fp,\replace(str,a,b); printf(\fprintf(fp,\fclose(fp); } 13、/*在一个字串s1中查找一子串s2,若存在则返回子串在主串中的起始位置 ,不存在则返回-1。*/ main() {char s1[6]=\printf(\system(\} int search(char s1[],char s2[]) {int i=0,j,len=strlen(s2); while(s1[i]){ for(j=0;j if(s1[i+j]!=s2[j]) break; if(j>=len)return i; else i++; } return -1; } 14、/*用指针变量输出结构体数组元素。*/ struct student { int num; char *name; char sex; int age; }stu[5]={{1001,\,19},{1004,\ main() {int i; struct student *ps; printf(\/*用指针变量输出结构体数组元素。*/ for(ps=stu;ps printf(\/*用数组下标法输出结构体数组元素学号和年龄。*/ for(i=0;i<5;i++) printf(\} 15、/*建立一个有三个结点的简单链表:*/ #define NULL 0 struct student { int num; char *name; int age ; struct student *next; }; void main() { struct student a,b,c,*head,*p; a.num=1001; a.name=\对结点成员进行赋值 */ b.num=1002; b.name=\c.num=1003; c.name=\ head=&a; /* 建立链表,a为头结点 */ a.next=&b; b.next=&c; c.next=NULL; p=head; /* 输出链表 */ do{ printf(\p=p->next; }while(p!=NULL); } 16、/*输入一个字符串,判断其是否为回文。回文字符串是指从左到右读和从右到左读完全相同的字符串。*/ #include { char s[100]; int i,j,n; printf(\输入字符串:\\n\ gets(s); n=strlen(s); for(i=0,j=n-1;i if(i>=j) printf(\是回文串\\n\ else printf(\不是回文串\\n\}