⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 icrc.for

📁 Numerical Recipes一书中例子的源码所用到的函数集,William H. Press 和 Saul A. Teukolsky 所著
💻 FOR
字号:
      FUNCTION icrc(crc,bufptr,len,jinit,jrev)
      INTEGER icrc,jinit,jrev,len
      CHARACTER*1 bufptr(*),crc(2)
CU    USES icrc1
      INTEGER ich,init,ireg,j,icrctb(0:255),it(0:15),icrc1,ib1,ib2,ib3
      CHARACTER*1 creg(4),rchr(0:255)
      SAVE icrctb,rchr,init,it,ib1,ib2,ib3
      EQUIVALENCE (creg,ireg)
      DATA it/0,8,4,12,2,10,6,14,1,9,5,13,3,11,7,15/, init /0/
      if (init.eq.0) then
        init=1
        ireg=256*(256*ichar('3')+ichar('2'))+ichar('1')
        do 11 j=1,4
          if (creg(j).eq.'1') ib1=j
          if (creg(j).eq.'2') ib2=j
          if (creg(j).eq.'3') ib3=j
11      continue
        do 12 j=0,255
          ireg=j*256
          icrctb(j)=icrc1(creg,char(0),ib1,ib2,ib3)
          ich=it(mod(j,16))*16+it(j/16)
          rchr(j)=char(ich)
12      continue
      endif
      if (jinit.ge.0) then
        crc(1)=char(jinit)
        crc(2)=char(jinit)
      else if (jrev.lt.0) then
        ich=ichar(crc(1))
        crc(1)=rchr(ichar(crc(2)))
        crc(2)=rchr(ich)
      endif
      do 13 j=1,len
        ich=ichar(bufptr(j))
        if(jrev.lt.0)ich=ichar(rchr(ich))
        ireg=icrctb(ieor(ich,ichar(crc(2))))
        crc(2)=char(ieor(ichar(creg(ib2)),ichar(crc(1))))
        crc(1)=creg(ib1)
13    continue
      if (jrev.ge.0) then
        creg(ib1)=crc(1)
        creg(ib2)=crc(2)
      else
        creg(ib2)=rchr(ichar(crc(1)))
        creg(ib1)=rchr(ichar(crc(2)))
        crc(1)=creg(ib1)
        crc(2)=creg(ib2)
      endif
      icrc=ireg
      return
      END

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -