此代码确实适用于代码块,但不适用于学校在线编译器。
给定一个长度为 S 的内存。每个位都可以用从 0 到 S-1 的索引进行标记。一开始内存是空的,到处都是0。
在第一行中,您必须输入 3 个整数:N、L 和 S。在接下来的 N 行中,将给出长度为 L 的数据,以最小距离 D=4 的汉明码编码。还有一个正整数,它在内存中标记汉明码如果正确接收到应该被复制的位置。
你必须检查是否有错误,如果没有错误你复制内存中的代码,如果有一个错误,你修复它而不是复制它,如果有两个错误你什么都不做。打印内存的最终内容..
输入示例:
1 5 128
0011010111 2
输出示例:
00101010000000
(有一点少于 128 个零,所以我不会全部输入)。:)
输入示例(2):
10 4 100
01111000 15
00110011 62
01110001 36
01101001 61
11100001 60
10101010 1
11111111 47
01101111 85
11111110 2
01010101 44
输出示例(2):
0111110000000001100000000000000000000000000000101110000000001000010000000000000000000000000000000000
我的解决方案(对于第一个示例):
#include <stdio.h>
#include <stdlib.h>
int main()
{
int a[100], b[5], c[200], N,L,S;
int i,j,k,r;
scanf("%d %d %d", &N, &L, &S);
for(i=0; i<N; i++)
{
int p1,p2,p3,p4;
for(j=1; j<L+7; j++)
{
scanf("%d", &a[j]);
}
p1 = (a[1]+a[3]+a[5]+a[7]+a[9])%2;
p2 = (a[2]+a[3]+a[6]+a[7])%2;
p3 = (a[4]+a[5]+a[6]+a[7])%2;
p4 = (a[8]+a[9]+a[10])%2;
if(p1==0 && p2==0 && p3==0 && p4==1) //first position
{
if(a[1]==0) a[1]=1;
else if(a[1]==1) a[1]=0;
}
if(p1==0 && p2==0 && p3==1 && p4==0) //second position
{
if(a[2]==0) a[2]=1;
else if(a[2]==1) a[2]=0;
}
if(p1==0 && p2==0 && p3==1 && p4==1) //third position
{
if(a[3]==0) a[3]=1;
else if(a[3]==1) a[3]=0;
}
if(p1==0 && p2==1 && p3==0 && p4==0) //fourth position
{
if(a[4]==0) a[4]=1;
else if(a[4]==1) a[4]=0;
}
if(p1==0 && p2==1 && p3==0 && p4==1) //fifth position
{
if(a[5]==0) a[5]=1;
else if(a[5]==1) a[5]=0;
}
if(p1==0 && p2==1 && p3==1 && p4==0) //sixth position
{
if(a[6]==0) a[6]=1;
else if(a[6]==1) a[6]=0;
}
if(p1==0 && p2==1 && p3==1 && p4==1) //seventh position
{
if(a[7]==0) a[7]=1;
else if(a[7]==1) a[7]=0;
}
if(p1==1 && p2==0 && p3==0 && p4==0) //eight position
{
if(a[8]==0) a[8]=1;
else if(a[8]==1) a[8]=0;
}
if(p1==1 && p2==0 && p3==0 && p4==1) //ninth position
{
if(a[9]==0) a[9]=1;
else if(a[9]==1) a[9]=0;
}
b[0]=a[3];
b[1]=a[5];
b[2]=a[6];
b[3]=a[7];
b[4]=a[9];
for(k=0; k<S-L; k++)
{
if(k==2)
{
for(r=0; r<5; r++)
printf("%d", b[r]);
}
else c[i]=0; printf("%d", c[i]);
}
}
return 0;
}