大一新生在学递归时碰到的问题

到很多地方求助都没有结果,来这里碰碰运气,谢谢大佬了。#include<stdio.h>

void selection_sort(int* arr,int n)
{
int count=0,tmp;
for(int j=0;j<n-1-count;j++)
{

   if(arr[j]>arr[j+1]){
    tmp=arr[j];
    arr[j]=arr[j+1];
    arr[j+1]=tmp;
}}
count++;
if(count!=n-1)

selection_sort(arr,n);
else return;

}
int main()
{int n;
scanf("%d",&n);
int a[n]={0};

for(int i=0;i<n;i++)

    scanf("%d",&a[i]);

selection_sort(a,n);
for(int k=0;k<n;k++)
printf("%d ",a[k]);
return 0;

}#include<stdio.h>

void selection_sort(int* arr,int n)
{
int count=0,tmp;
for(int j=0;j<n-1-count;j++)
{

   if(arr[j]>arr[j+1]){
    tmp=arr[j];
    arr[j]=arr[j+1];
    arr[j+1]=tmp;
}}
count++;
if(count!=n-1)

selection_sort(arr,n);
else return;

}
int main()
{int n;
scanf("%d",&n);
int a[n]={0};

for(int i=0;i<n;i++)

    scanf("%d",&a[i]);

selection_sort(a,n);
for(int k=0;k<n;k++)
printf("%d ",a[k]);
return 0;

}

#include<stdio.h>
#include<math.h>
int quickerpower(int x,int n)
{
if(n%2==0)
return quickerpower(x,n/2)quickerpower(x,n/2);
else if(n%2!=0)
return x
quickerpower(x,n-1);
else if(n==0)
return 1;
}
int main()
{
int x=3,n=2,a;
a=quickerpower(3,2);
printf("%d %d",a,pow(x,n));
return 0;
}这两个递归都写错了啊,怎么改都不对。

img

img

img

第一题和第七题。

修改如下,供参考:

//编写程序,要求用户登录一串整数(把这串整数存储在数组中),
//然后通过调研selectio_sort函数来排序这些整数。
//在给定n个元素数组后,selection_sort函数必须做下列工作:
//a.搜索数组找出最大的元素,然后把它移到数组的最后
//b.递归地调用函数本身来对前n-1个数组元素进行排序。
#include <stdio.h>
#define N 10
void selection_sort(int* arr, int n)
{
    int i, t, imax = 0;
    if (n < 1) return;
    for (i = 1; i < n; ++i) {
        if (arr[imax] < arr[i])
            imax = i;
    }
    if (imax != n - 1) {
        t = arr[n - 1];
        arr[n - 1] = arr[imax];
        arr[imax] = t;
    }
    selection_sort(arr, n - 1);
}
int main()
{
    int n;
    int a[N] = { 0 };
    scanf("%d", &n);
    for (int i = 0; i < n; i++)
        scanf("%d", &a[i]);
    selection_sort(a, n);
    for (int k = 0; k < n; k++)
        printf("%d ", a[k]);
    return 0;
}


//换一种方法计算x^n,如果n是2的幂,则可以通过自乘的方法计算x^n.
//如果n是偶数,可以用公式x^n=(x^n/2)^2;
//如果n是奇数,则x^n=x*x^n-1.
#include<stdio.h>
int quickerpower(int x, int n)
{
    if (n == 0)
        return 1;
    if (n % 2 == 0)
        return quickerpower(x, n / 2) * quickerpower(x, n / 2);
    else if (n % 2 != 0)
        return x * quickerpower(x, n - 1);
}
int main()
{
    int x = -3, n = 2, a;
    a = quickerpower(x, n);
    printf("%d", a);
    return 0;
}


for(){
条件
}else{
条件

可以去学习一下条件语句的用法,for…else/if…else

递归的思想就是把一个大问题转换成一个个小问题来去求解,不要总是在脑子里想,我递归到底部是什么样的,然后在一步步推上来是怎么样的,这样是写不好递归的。你应该想的是,1. 递归该什么时候停止,2. 在当前这一个子问题中应该做什么,3. 该如何给下一步参数。至于上面的代码就不分析了,格式太混乱了。