下沙论坛

 找回密码
 注册论坛(EC通行证)

QQ登录

QQ登录

下沙大学生网QQ群8(千人群)
群号:6490324 ,验证:下沙大学生网。
用手机发布本地信息严禁群发,各种宣传贴请发表在下沙信息版块有问必答,欢迎提问 提升会员等级,助你宣传
新会员必读 大学生的论坛下沙新生必读下沙币获得方法及使用
查看: 2432|回复: 29
打印 上一主题 下一主题

〓〓救命啊,懂计算机的人帮帮我啊〓〓

[复制链接]

该用户从未签到

跳转到指定楼层
1
发表于 2005-6-15 20:33:00 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
谁能帮我把这个CRC校验编程实现啊(就是换个编法)??万分感谢,帮我顶啊
. ]- l0 u" m& v8 v/ s0 g#include<IOSTREAM.H>5 l: N/ ?- I+ Y
#include<STDLIB.H>
+ p. Q' `$ A) h: l: b! Y#include<STRING.H>7 X+ [* {5 R8 P( d; \- }; |; g
#define CRC 5
2 N/ l- L* Z+ U! R2 S7 A  k. {char data[5]={'1','1','0','0','1'};
! |4 K4 ?; G, W% P$ r) g* zclass Checkout( l4 y( Q+ o1 O: o# K% Z
{! R9 Y  q6 n6 [/ \4 y" w# K" N
private:1 ]* {0 k  v# N: [3 l- }& {" |4 f
char ax[50];
( v3 F" F9 B0 O9 X' S1 rchar bx[4];8 I; O7 w1 I  J) q5 ^
int x;
/ p: d- V$ w0 Y6 t" Y( Mpublic:
* {: t) a9 b- a% R5 Dint length;
3 u1 U  B! x4 O, i' M5 _# fCheckout()
4 i$ K) L, U* U% J. e  M" n+ E{  
; p9 y+ N0 Q( J+ `6 Y0 W- d+ s  cin&gt;&gt;ax;% J( |8 s; Y2 f& w. o3 `8 M: C- [
  length=strlen(ax);
8 y- K% \8 v& O1 |7 l8 Y}4 e2 F8 r1 k: D7 k8 E
void cxc();* @& q' j8 i9 m; c" H2 ~1 ~
bool qyu();0 B) R5 y; i  I. d
void add();3 `$ x3 m2 ^6 K: |3 Z& N& |# S
};
% Z, c3 I+ \% Uvoid Checkout::cxc()
' g# m9 `1 F, g{
+ ?- ~6 a9 A2 efor(int i=0;i&lt;4;i++){+ _  r, y: Z5 q. K! @
  ax[length+i]='0';) O' b+ U1 h& }0 @+ d9 |% z
}
# n- G. J6 W5 o) A! E- x}//将输入序列后加4个0# w* ?# f* o1 C# I% X2 ~
bool Checkout::qyu()1 b" Y6 N* G% m0 E
{0 R! H  ~: i9 e' x- [3 I
char c[5];
7 R2 K- U% J4 J) c. r; ^8 A# Lint i,j,n;
: ~% ^! V' `* ]* T' w: j( a; {/ Gint m=5;
6 q. J8 X( \4 }1 s- D: G, Z% qfor(i=0;ax=='0';i++);+ H" K2 m6 I7 |, K
  if(i==length)
- ]& d+ j7 X4 k8 e9 U9 G  {cout&lt;&lt;"余式是0"&lt;<ENDL;
4 j$ @8 w+ A5 k  q: H4 m1 r8 ^0 v   cout&lt;&lt;"发送成功"&lt;<ENDL;3 y7 c1 f- A% E& l% q) z, \8 O- Y7 H
   exit(0);
  R. p) a( V+ j4 y8 L% k% G  }
4 y5 r8 S2 q7 _! y' A  W' felse{! Y- R* s2 N- w. M
for(i=0;i&lt;5;i++)
2 L) b: e2 P' j6 w. d0 V7 K, w  p  c=ax;
  z& L1 g8 O( h" Qwhile(m==CRC)
" r' R' p) ^5 X' N: {# }( |% ^0 W{ for(j=0;j<CRC;J++)& _: C5 A" `- V5 {
   {
( F2 N1 f$ O. u                if(c[j]==data[j])
! g. J+ M- J6 P6 R, a. S     c[j]='0';
5 ~: K& x$ @- P    else
- h+ E/ N! ?/ Y# J/ G( u5 W6 r( D     c[j]='1';
) k" ^# k) v; _, P. L# ?! A" C   }
1 b1 f! u6 [4 S& y9 @4 j1 M+ }     for(j=0;c[j]=='0';j++);3 I# M5 a1 b; n: P2 N2 ^7 K
       n=j;0 I9 F: e, h4 I  t" X4 \: N+ g
     for(m=0;m<CRC-N;M++)6 R; ]3 B9 ]4 q- g) I9 ~$ u
     {' j2 C+ o+ h. N
    c[m]=c[j];8 m" V2 t, n) m. S- p
    j++;  H7 v4 I$ S7 Q+ o: |$ q+ Q
   }! [9 s" [7 `/ I0 `2 x4 P
           while(i<LENGTH&&M<5)
/ h+ s9 H/ J# Z" f. J   {% B% m+ ?+ X8 B" T: `
        c[m]=ax[i++];
+ x0 T) A% ]: p) ^     m++;       3 a! p6 L2 f# H
   }# \5 v6 S8 G5 {3 {7 ^& O! f" s
}
( G- Z* B5 |. v" H}
! c9 W- N& M7 I2 Bint k;" Z. J* H7 `7 ]/ t; l$ N1 C
for(k=0;k<M;K++)% _) }' D1 R! l0 B- Z
  bx[k]=c[k];4 }' j2 K0 m5 T8 V* o
for(j=0;bx[j]=='0';j++);/ z3 I" j! u! C5 k, J: n
  if(j==m)! M% `( R6 T9 D: k$ S9 \( ^$ ^
  {cout&lt;&lt;'0'&lt;<ENDL;
; o( s+ l% k  E* y2 v# T$ h5 J7 p   x=0;1 d" {5 z; K# F; ~; R
  return true;
( p8 M) o3 e( X& n& b3 }. Y2 s  }
- c2 r2 @( ]8 ^' |4 B- g  else
! q/ i  j0 S: e. C7 C4 R2 l  {for(n=j;n<M;N++)* ]2 f1 ~0 q7 ]
     cout&lt;<BX[N];
9 g4 U' k4 F6 m* E2 E  x=m-j;
: i, Y. B+ m. h) M- N  cout&lt;<ENDL;; L6 [. p( f3 q8 u
  return false;
4 z- n7 V5 }" `* K  }6 F. e4 g: z9 P
}: ~( }1 y9 L# B/ s9 w- `* S
void Checkout::add()
7 j/ Z- H8 z7 S5 m+ D; o2 j7 {( Z{
3 H6 k. V1 Q' q  |/ W+ |( Bint j=0;# V0 w8 Y. }" U$ N7 b% o* n/ R2 |
  for(int i=length-x;i<LENGTH;I++)
% |  F/ O. q; C" r; ^. Y1 b+ a    ax=bx[j++];. G$ T7 \& B4 |# j+ j
  cout&lt;&lt;"发送的序列加上余数后变成:";0 V0 m' ?/ T* [- [4 r
for(i=0;i<LENGTH;I++)* q  L- t4 a: x; C( X9 l
  cout&lt;<AX[I];
( {( G( h7 e3 P3 L- Y" D6 ?& t" s" p cout&lt;<ENDL;
& n3 _% @1 o% t) k}  }& A/ U- u" `
void main()1 h. C# F4 t3 Y3 p
{  
! A% i7 \/ g  `7 d9 ocout&lt;&lt;"本次实验模拟CRC校验,其生成多项式的比特序列是11001"&lt;<ENDL;
) y% R; H! E. c0 h* Q4 x* V    cout&lt;&lt;"请输入发送数据比特序列:"&lt;<ENDL;
9 e. b9 t- }4 i# _- { Checkout test;  O9 M3 Q' K  x6 t! C/ m3 r' h: A
test.cxc();
; t( r& f/ e- g+ G& q' c5 M' s  cout&lt;&lt;"余式比特序列是:";5 x$ }+ v" O' l7 c5 |
  test.qyu();
; O4 Q8 H% H7 `0 v) `  test.add();& ?, R- j" w4 Z* \. f( C( Q
  cout&lt;&lt;"试试这次是否能被整除."&lt;<ENDL;) G* ^$ \# V3 R4 R' J# ]
cout&lt;&lt;"新余数是:";
$ N" l6 @; ~# ~0 x) C  if(test.qyu()). _( a$ r" G0 S2 Z6 N( @# U
   cout&lt;&lt;"已发送成功!"&lt;<ENDL;
6 R) e0 L! Z; X3 I  else7 X% j; N+ B4 p
   cout&lt;&lt;"未发送,失败!"&lt;<ENDL;0 W1 J; K2 g) U; D5 w5 E- q7 h! S
}/ U0 O; K2 G7 B
[此贴子已经被作者于2005-6-15 20:46:33编辑过]
: U/ c# H( d% D0 r2 k
分享到:  QQ好友和群QQ好友和群 QQ空间QQ空间 腾讯微博腾讯微博 腾讯朋友腾讯朋友
收藏收藏 分享分享 顶 踩

该用户从未签到

2
发表于 2005-6-15 20:34:00 | 只看该作者
忘了呢,顶上先.来个人,帮帮他

该用户从未签到

3
发表于 2005-6-15 20:35:00 | 只看该作者
复杂

该用户从未签到

4
 楼主| 发表于 2005-6-15 20:37:00 | 只看该作者
HELP

该用户从未签到

5
发表于 2005-6-15 20:39:00 | 只看该作者
UP

该用户从未签到

6
发表于 2005-6-15 20:39:00 | 只看该作者
呵呵,等等,有人来的

该用户从未签到

7
发表于 2005-6-15 20:39:00 | 只看该作者
估计会的都不来

该用户从未签到

8
发表于 2005-6-15 20:40:00 | 只看该作者
完全看不懂

该用户从未签到

9
发表于 2005-6-15 20:42:00 | 只看该作者
<DIV class=quote><B>以下是引用<I>xushengsy</I>在2005-6-15 20:40:10的发言:</B>
1 i# m2 X6 q0 _" D完全看不懂</DIV>1 O3 E/ g5 {* E* w- I5 v4 z

- S$ |/ Y. q& C& v! G, |2 B不是吧

该用户从未签到

10
 楼主| 发表于 2005-6-15 20:45:00 | 只看该作者
。。。。。。。。。。顶

该用户从未签到

11
发表于 2005-6-15 20:46:00 | 只看该作者
看天书也要比这个容易

该用户从未签到

12
 楼主| 发表于 2005-6-15 20:47:00 | 只看该作者
<>就是换个编法。。。。。性质一样的。。。。</P><>谁帮我改一下啊</P>

该用户从未签到

13
 楼主| 发表于 2005-6-15 20:51:00 | 只看该作者
<>就是换个编法。。。。。性质一样的。。。。</P><>谁帮我改一下啊</P>

该用户从未签到

14
发表于 2005-6-15 20:54:00 | 只看该作者
我还是友情支持下把

该用户从未签到

15
发表于 2005-6-15 20:55:00 | 只看该作者
<> 闪过...</P>

该用户从未签到

16
 楼主| 发表于 2005-6-15 21:24:00 | 只看该作者
  • TA的每日心情
    奋斗
    2018-5-4 03:27
  • 签到天数: 2 天

    [LV.1]初来乍到

    17
    发表于 2005-6-15 21:27:00 | 只看该作者
    天书啊 !!!

    该用户从未签到

    18
    发表于 2005-6-15 21:27:00 | 只看该作者
    姘头是什么意思啊

    该用户从未签到

    19
    发表于 2005-6-15 21:30:00 | 只看该作者
    <>嘿嘿</P><>偶也顶虽然我也知道怎么做</P>

    该用户从未签到

    20
     楼主| 发表于 2005-6-15 21:33:00 | 只看该作者
    <>楼上地大哥帮下忙啊</P>

    本版积分规则

    关闭

    下沙大学生网推荐上一条 /1 下一条

    快速回复 返回顶部 返回列表