1.将自己编写好的strlen strcpy strcmp strcat 打包成函数。
mystrlen , mystrcpy mystrcmp mystrcat.
#include <stdio.h>
int mystrlen(char arr[]);
char mystrcpy(char arr[],char str[]);
void mystrcmp(char arr[],char str[]);
void mystrcat(char arr[],char str[]);
int main(int argc, const char *argv[])
{
char arr[100];
char str[100];
printf("请输入字符串:");
gets(arr);
printf("请输入字符串:");
gets(str);
mystrlen(arr);
return 0;
}
int mystrlen(char arr[])
{
int i;
for(i=0;arr[i]!='\0';i++)
{
}
printf("len=%d\n",i);
return i;
}
char mystrcpy(char arr[],char str[])
{
int i;
for(i=0;;i++)
{
arr[i]=str[i];
if(str[i] == '\0')
break;
}
printf("%s\n",arr);
}
void mystrcmp(char arr[],char str[])
{
int i=0;
int res;
for(i=0;;i++)
{
res = arr[i]-str[i];
if(res!=0)
{
break;
}
else if(str[i]=='\0')
{
break;
}
}
printf("res=%d\n",res);
}
void mystrcat(char arr[],char str[])
{
int i,j;
for(i=0;str[i]!='\0';i++);
for(j=0;;i++,j++)
{
str[i]=arr[j];
if('\0'==arr[j])
break;
}
printf("%s\n",str);
}
b.mystrcpy mystrcmp mystrcat不需要返回值,因为指针没讲,无法返回数组
2.求斐波那契数列的第n项。
1、1、2、3、5、8、13、21、34、......,第一项和第二项 时候都是输出1
公式:f(n) = f(n-1)+f(n-2); 例如第20项,6765
#include <stdio.h>
int series(int n);
int main(int argc, const char *argv[])
{
int k,n;
printf("请输入斐波那契数列的第n项:");
scanf("%d",&n);
k = series(n);
printf("斐波那契数列的第%d项=%d\n",n,k);
return 0;
}
int series(int n)
{
if(n==1 || n==2)
{
return 1;
}
else
{
return n=series(n-1)+series(n-2);
}
}
运行结果:
3.输出一个十行的杨辉三角。
提示:当前数据 = 上一行的当前列 + 上一行的前一列
1
1 1
1 2 1
1 3 3 1
1 4 6 4 1
1 5 10 10 5 1
1 6 15 20 15 6 1
1 7 21 35 35 21 7 1
1 8 28 56 70 56 28 8 1
1 9 36 84 126 126 84 36 9 1
#include <stdio.h>
int main(int argc, const char *argv[])
{
char arr[10][10];
int i,j;
for(i=0;i<10;i++)
{
for(j=0;i>=j;j++)
{
if(i>=2 && j>0 && j<i )
{
arr[i][j]=arr[i-1][j]+arr[i-1][j-1];
}
else if(i==j || j==0 )
{
arr[i][j]=1;
}
printf("%d",arr[i][j]);
printf(" ");
}
printf("\n");
}
return 0;
}
运行结果: