C语言编程 设有一数列, 包含10个数, 已按升序排好。,16,18,20 ,

设有一数列, 包含10个数, 已按升序排好。 现要求编写一程序, 它能够把从指定位置开始的n个数按逆序重新排列并输出完整的数列。 例如: 原数列为2,4,6,8,10,12,14,16,18,20 , 如果要求从第4个数开始的5个数按逆序重排列, 则得到的新数列为 2,4,6,16,14,12,10,8,18,20

已验证

int main()
{
int a[10], i, j, t;
printf("输入数组元素:\n");
for(i=0; i<10; i++)
scanf("%d", &a[i]);
for(i=1; i<10; i++)
{
for(j=0; j<10-i; j++)
{
if(a[j]>a[j+1])
{
t=a[j]; a[j]=a[j+1]; a[j+1]=t;
}
}
}
for(i=1; i<6; i++)
{
for(j=3; j<8-i; j++)
{
if(a[j]<a[j+1])
{
t=a[j]; a[j]=a[j+1]; a[j+1]=t;
}
}
}
printf("输出排序后的数组元素:\n");
for(i=0; i<10; i++)
printf("%d\t", a[i]);
return 0;
}
温馨提示:答案为网友推荐,仅供参考
第1个回答  2009-12-13
写一个函数,应该就可以了
#include<stdio.h>

void order(int k,int n,int a[10]){
//k未开始位置
//n为要逆序的数个数
int b;
if(k>=10){
printf("输入的起始位置不正确");
}else{
if(k+n>=10){
for(int i =0;i<(10-k)/2;i++){
b=a[k+i];
a[k+i]=a[9-i];
a[9-i] = b;
}
}
if(k+n<10)
{
for(int i =0;i<n/2;i++){
b = a[k+i];
a[k+i]=a[k+n-i];
a[k+n-i]=b;
}
}
}
for(int i=0;i<10;i++){
printf("%d\t",a[i]);
}
printf("\n");
}
这是测试函数:
void main(){
int a,b[10]={2,4,6,8,10,12,14,16,18,20};
order(2,4,b);
for(int i=0;i<10;i++){
printf("%d\t",b[i]);
}
scanf("%d",a);
}
第2个回答  2009-12-13
这个很简单啊:
1.建两个数组
2.A数组存放10个原始数据
3.从A数组拷贝“从指定位置开始的n个数”存放在B数组中
4.对B数组排序
5.把B数组替换A数组总从指定位置开始的N个数。