到很多地方求助都没有结果,来这里碰碰运气,谢谢大佬了。#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 xquickerpower(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;
}这两个递归都写错了啊,怎么改都不对。
修改如下,供参考:
//编写程序,要求用户登录一串整数(把这串整数存储在数组中),
//然后通过调研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. 该如何给下一步参数。至于上面的代码就不分析了,格式太混乱了。