EAN码校验位的计算方法

/**
   EAN码校验位的计算方法
   从代码位置序号2开始,所有偶数位的数字代码求和为a。
   将上步中的a乘以3为a。
   从代码位置序号3开始,所有奇数位的数字代码求和为b。
   将a和b相加为c。
   取c的个位数d。
   用10减去d即为校验位数值。

   例:234235654652的校验码的计算如下表:

   数据码 校验码
   代码位置序号 13 12 11 10 9 8 7 6 5 4 3 2 1
   数字码 2 3 4 2 3 5 5 5 4 6 5 2 ?
   偶数位     3 + 2 + 5 + 5 + 6 + 2
   奇数位 2 + 4 + 3 + 5 + 4 + 5

   步骤1:3+2+5+5+6+2=23
   步骤2:23*3=69
   步骤3:2+4+3+5+4+5=23
   步骤4:69+23=92
   步骤5:10-2=8
   步骤6:校验码为 8


   数据码 校验码
   代码位置序号 18 17 16 15 14 13 12 11 10 9 8 7 6 5 4 3 2 1
   数字码 2 0 0 0 0 0 5 0 0 2 2 0 0 0 1 4 7 ?
   偶数位 2 + 0 + 0 + 5 + 0 + 2 + 0 + 1 + 7
   奇数位      0 + 0 + 0 + 0 + 2 + 0 + 0 + 4

   步骤1:2+0+0+5+0+2+0+1+7=17
   步骤2:17*3=51
   步骤3:0+0+0+0+2+0+0+4=6
   步骤4:51+6=57
   步骤5:10-7=3
   步骤6:校验码为 3

  */ 
  

///


  /// EAN码校验位的计算
  ///

  ///
  ///
  private bool GetVerifyBit(ref string szCode)
  {
   int nNum1 = 0;
   int nNum2 = 0;
   int nNum3 = 0;
   int szLen = 0; 
   if ( szCode == null )
    return false;
   
   szLen = szCode.Length;    
   if(szLen <=12 || szLen >= 17)
        return true;
   for ( int i=0; i   {   

    if ( i%2 == 0 )
    {
     nNum2 += int.Parse(szCode[i].ToString()); //偶数     
    }
    else
    {
     nNum1 += int.Parse(szCode[i].ToString()); //奇数     
    }
   }
   nNum3 = (Operator.DiscountLabelBarLength % 2 ==0) ? nNum1 + nNum2 * 3 : nNum1 * 3 + nNum2 ; 
   
   int t ;
   if(nNum3%10>0) t= 10- (nNum3 % 10) ;
   else t=0;
   szCode+=t;

   return true
  }

    

///


  /// EAN码校验位的计算
  ///

  ///
  ///
  private bool GetVerifyBit(ref string szCode)
  {
   int nNum1 = 0;
   int nNum2 = 0;
   int nNum3 = 0;
   int szLen = 0; 
   if ( szCode == null )
    return false;
   
   szLen = szCode.Length;    
   if(szLen <=12 || szLen >= 17)
        return true;
   for ( int i=0; i   {   

    if ( i%2 == 0 )
    {
     nNum2 += int.Parse(szCode[i].ToString()); //偶数     
    }
    else
    {
     nNum1 += int.Parse(szCode[i].ToString()); //奇数     
    }
   }
   nNum3 = (Operator.DiscountLabelBarLength % 2 ==0) ? nNum1 + nNum2 * 3 : nNum1 * 3 + nNum2 ; 
   
   int t ;
   if(nNum3%10>0) t= 10- (nNum3 % 10) ;
   else t=0;
   szCode+=t;

   return true
  }

    

    

如果再精简些应该直接用数组类型来实现,这样就不用使用string了.代码中的细节部分不是效率最高写法.盖于本人学历尚浅,对char等类型掌握的还不熟.所以就用一堆的转型来解决了.

代码用c#写成,相信学java人士也能看懂吧 呵呵

前几天上传得代码有问题居然没人发现,汗,还是自己改过来吧...现在已经改完了,不知道会不会有其他得问题了,欢迎批评啊

你可能感兴趣的:(算法的思考)