数组排序和查找(指针)

13 篇文章 1 订阅

输入10个整数,编写函数sort, 按绝对值从小到大排序, 并返回绝对值最大整数在原数组中的下标。按要求编写sort()。

#include<stdio.h>
#include<math.h>

void  sort(int a[], int n, int *p2)
{
    int i = 0,j = 0;
    *p2 = 0;
    int *p = a;
    //找出元素中绝对值最大的下标
    for (i = 0; i < 10 - 1; i++)
    {
        if (abs((*p + i)) < abs( *(p + i + 1)))//abs为取绝对值函数,头文件为<math.h>
            *p2 = i + 1;
    }//for
    //按绝对值大小进行升序冒泡排序
    for (i = 0; i < 10 - 1; i++)//进行冒泡排序的次数
    {//进行冒泡排序的趟数
        for (j = 0; j < 10 - 1; j++)
        {
            if (abs( *(p + j)) > abs( *(p + j + 1)))
            {
                int t;
                t = *(p + j);
                *(p + j) = *(p + j + 1);
                *(p + j + 1) = t;
            }//if           
        }//for
    }//for
}//sort

int main()
{
    int a[10], i;
    int imax = 0;
    // printf("请输10个整数:\n");
    for (i = 0; i < 10; i++)
        scanf("%d", &a[i]);
    sort(a, 10, &imax);//冒泡排序 
    // printf("按绝对值从小到大排序后:\n");
    printf("imax=%d\n", imax); // 输出绝对值最大数在原数组中下标
    for (i = 0; i < 10; i++)
        printf("%5d", a[i]);
    return 0;
}

 注:abs为取绝对值函数,头文件为<math.h>

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值