栏目分类:
子分类:
返回
名师互学网用户登录
快速导航关闭
当前搜索
当前分类
子分类
实用工具
热门搜索
名师互学网 > IT > 软件开发 > 后端开发 > C/C++/C#

数组排序和查找(指针)

C/C++/C# 更新时间: 发布时间: IT归档 最新发布 模块sitemap 名妆网 法律咨询 聚返吧 英语巴士网 伯小乐 网商动力

数组排序和查找(指针)

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

#include
#include

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为取绝对值函数,头文件为
            *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=%dn", imax); // 输出绝对值最大数在原数组中下标
    for (i = 0; i < 10; i++)
        printf("%5d", a[i]);
    return 0;
}

 注:abs为取绝对值函数,头文件为

转载请注明:文章转载自 www.mshxw.com
本文地址:https://www.mshxw.com/it/589589.html
我们一直用心在做
关于我们 文章归档 网站地图 联系我们

版权所有 (c)2021-2022 MSHXW.COM

ICP备案号:晋ICP备2021003244-6号