CF1206B Make Product Equal One

Posted lyt020321

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CF1206B Make Product Equal One相关的知识,希望对你有一定的参考价值。

技术图片
技术图片


思路

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

如果是零的话,我们就把他转化成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的主要内容,如果未能解决你的问题,请参考以下文章

CF864D Make a Permutation!

CF1042C Array Product 分类讨论+贪心

CF1095F Make It Connected

CF1206BMake Product Equal One

[CF 1043F] Make It One

CF1064A Make a triangle!