C语言编程 设有一数列, 包含10个数, 已按升序排好。,16,18,20 ,
设有一数列,包含10个数,已按升序排好。现要求编写一程序,它能够把从指定位置开始的n个数按逆序重新排列并输出完整的数列。例如:原数列为2,4,6,8,10,12,14,1...
设有一数列, 包含10个数, 已按升序排好。 现要求编写一程序, 它能够把从指定位置开始的n个数按逆序重新排列并输出完整的数列。 例如: 原数列为2,4,6,8,10,12,14,16,18,20 , 如果要求从第4个数开始的5个数按逆序重排列, 则得到的新数列为 2,4,6,16,14,12,10,8,18,20
展开
3个回答
展开全部
已验证
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;
}
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;
}
展开全部
写一个函数,应该就可以了
#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);
}
#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);
}
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
展开全部
这个很简单啊:
1.建两个数组
2.A数组存放10个原始数据
3.从A数组拷贝“从指定位置开始的n个数”存放在B数组中
4.对B数组排序
5.把B数组替换A数组总从指定位置开始的N个数。
1.建两个数组
2.A数组存放10个原始数据
3.从A数组拷贝“从指定位置开始的n个数”存放在B数组中
4.对B数组排序
5.把B数组替换A数组总从指定位置开始的N个数。
已赞过
已踩过<
评论
收起
你对这个回答的评价是?
推荐律师服务:
若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询