6/5作业

1.思维导图

2.牛客网理论

3.

#include <stdio.h>
#include <string.h>
#include <stdlib.h>
int fun(int n);
int main(int argc, const char *argv[])
{
    int n;
    scanf("%d",&n);
    printf("%d\n",fun(n));
    return 0;
}
int fun(int n)
{
    if(n==0)
        return 0;
    else
        return n%10+fun(n/10);
}                                            
                                             
                                             
                                             

4.输入一个字符串,使用递归实现字符串的逆置


                                                        
                                                        
                                                        
                                                   #include <stdio.h>                                          
#include <string.h>
#include <stdlib.h>
void fun(int i,int j,char n[]);
int main(int argc, const char *argv[])
{
    char n[128]={};
    gets(n);
    int len=strlen(n);
    fun(0,len-1,n);
    puts(n);
    return 0;
}
void fun(int i,int j,char n[])
{
    char t;
    if(i>=j)
        return 0;
    else
    {
        t=n[i];
        n[i]=n[j];
        n[j]=t;
        return fun(i+1,j-1,n);
    }
}
                                                            
                                                            
                                                            
     
                                                        
                                                        
                                                        
                                                        
                                                        
                                                        

5.使用递归实现斐波那契

#include <stdio.h>                                                               
#include <string.h>
#include <stdlib.h>
int fun(int n);
int main(int argc, const char *argv[])
{
    int i;
    for(i=1;i<=10;++i)
        printf("%d ",fun(i));
    printf("\n");
    return 0;
}
int fun(int n)
{
    if(n==1||n==2)
        return 1;
    else
        return fun(n-1)+fun(n-2);
}
                                                                                 
                                                                                 
                                                                                 
                                                                                 
                                                                                 
                                                                                 
                                                                                 
                                                                                 

6.在主函数中定义两个字符串,实现字符串的比较,返回差值

#include <stdio.h>                                                  
#include <string.h>
#include <stdlib.h>
int fun(char n[],char a[]);
int main(int argc, const char *argv[])
{
    char n[128]={};
    char a[128]={};
    gets(n);
    gets(a);
    int arr=fun(n,a);
    printf("差值为%d\n",arr);
    return 0;
}
int fun(char n[],char a[])
{
    int i=0;
    while(n[i]==a[i])
    {
        if(n[i]=='\0')
            break;
        i++;
    }
    return n[i]-a[i];
}
                                                                    
                                                                    
                                                                    
                                                                    
                                                                    

i=0      c:4    b:4     sum(0)=8

i=1      c:4    b:6     sum(1)=11

i=2      c:4    b:6     sum(2)=12

评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值