亦清y 2021-12-15 14:11 采纳率: 71.4%
浏览 49
已结题

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

到很多地方求助都没有结果,来这里碰碰运气,谢谢大佬了。#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

第一题和第七题。

  • 写回答

2条回答 默认 最新

  • qzjhjxj 2021-12-15 16:38
    关注

    修改如下,供参考:

    //编写程序,要求用户登录一串整数(把这串整数存储在数组中),
    //然后通过调研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;
    }
    
    
    
    本回答被题主选为最佳回答 , 对您是否有帮助呢?
    评论
查看更多回答(1条)

报告相同问题?

问题事件

  • 已结题 (查看结题原因) 12月16日
  • 已采纳回答 12月15日
  • 创建了问题 12月15日

悬赏问题

  • ¥15 2020长安杯与连接网探
  • ¥15 关于#matlab#的问题:在模糊控制器中选出线路信息,在simulink中根据线路信息生成速度时间目标曲线(初速度为20m/s,15秒后减为0的速度时间图像)我想问线路信息是什么
  • ¥15 banner广告展示设置多少时间不怎么会消耗用户价值
  • ¥16 mybatis的代理对象无法通过@Autowired装填
  • ¥15 可见光定位matlab仿真
  • ¥15 arduino 四自由度机械臂
  • ¥15 wordpress 产品图片 GIF 没法显示
  • ¥15 求三国群英传pl国战时间的修改方法
  • ¥15 matlab代码代写,需写出详细代码,代价私
  • ¥15 ROS系统搭建请教(跨境电商用途)