求绝对值最大值(打擂法)

Problem Description
求n个整数中的绝对值最大的数。
Input
输入数据有2行,第一行为n,第二行是n个整数。
Output
输出n个整数中绝对值最大的数。
Example Input
5
-1 2 3 4 -5
Example Output

-5

思路:打擂法求最大值,首先输入第一个m, 求绝对值,令绝对值成为max,然后对后续n-1个数和他作比较,如果max小于fm则max= fm,然后就求出来了。打擂法在历史上很常见,比较军阀混战时候,总有一个军阀先称帝,做了max,然后后面其他的军阀比他强,大于他,就称帝,一番混战,做了for循环后,就得到了最大的,恩。。。。这个人就是司马式做了皇帝。。。。

#include <stdio.h>
#include <stdlib.h>


int main()
{
    int n, i, m, fm, max, maxold;
    scanf("%d", &n);
    scanf("%d", &m);
    fm = m;
    if(m < 0)
    {
        fm = -m;
    }
    max = fm;
    maxold = m;
    for(i = 1; i < n; i++)
    {
        scanf("%d", &m);
        fm = m;
        if(m < 0)
        {
            fm = - m;
        }
        if(max < fm)
        {
            max = fm;
            maxold = m;
        }
    }
    printf("%d\n", maxold);


    return 0;
}

  • 0
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值