首页 > 其他 > 详细

CF1206B Make Product Equal One

时间:2019-08-22 13:37:18      阅读:85      评论:0      收藏:0      [点我收藏+]

技术分享图片
技术分享图片


思路

有一个很显然的思路就是分正负

如果是零的话,我们就把他转化成1,反正答案一定会+1

如果是正数,就传话为1

如果是负数,就转化为-1

如果负数的个数是偶数个,那当然最好,如果是奇数个,那就处理一下


#include <bits/stdc++.h>
#define int long long
using namespace std ;
int n , A , B , C ,ans = 0 , lop = 1 ;
signed main () {
    cin >> n ;
    for(int i = 1 ; i <= n ; i ++) {
        int x ;cin >> x ;
        if(!x) C ++ ;
        else if(x > 0) {
            ans += x-1 ;
        }else if(x < 0) {
            ans += -1-x ;
            lop *= -1 ;
        }
    }
    if(lop == -1 && !C) {
        ans += 2 ;
    }
    cout << ans + C<<endl ;
    return 0 ;
}

溜了溜了

CF1206B Make Product Equal One

原文:https://www.cnblogs.com/lyt020321/p/11393379.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!