【C语言程序】基因编码

输入一个长为n=2k(k≤8)01串s,按照"ABC编码规则"进行编码,ABC编码规则是:

                                                                 A                      //若s串全是0

                                                  T(s)=       B                      //若s串全是1

                                                                 CT(s1)T(s2)     //否则把s串分成两个等长的子串s1和s2

例如:

     T(01001011)

=CT(0100)T(1011)

=CCT(01)T(00)CT(10)T(11)

=CCCT(0)T(1)ACCT(1)T(0)B

=CCCABACCBAB

#include <stdio.h>
#include <string.h>
void f(char a[],int begin,int end)
{
int num_A=0,num_B=0;
int i;
for(i=begin;i<end;i++)
{
if(a[i]=='0')
num_A++;         //记录0的个数 
else if(a[i]=='1')
num_B++;         //记录1的个数 
}
if(num_A==end-begin)//如果该数组全为0 
printf("A");
else if(num_B==end-begin)//如果该数组全为1 
printf("B");
else
{
printf("C");
f(a,begin,(end+begin)/2); 
f(a,(end+begin)/2,end);
}
}
int main()
{
char a[500];
int length;
gets(a);
length=strlen(a);
f(a,0,length);
return 0;
}

 

 

  

 

 

转载于:https://www.cnblogs.com/levelstrcpy/p/7842971.html

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
最全ASCII码对照表 Bin               Dec     Hex         缩写/字符                                       解释 0000 0000     0           00             NUL (null)                                       空字符    0000 0001     1           01             SOH (start of handing)                   标题开始  0000 0010     2           02             STX (start of text)                           正文开始  0000 0011     3           03             ETX (end of text)                           正文结束 0000 0100     4           04             EOT (end of transmission)             传输结束  0000 0101     5           05             ENQ (enquiry)                               请求  0000 0110     6           06             ACK (acknowledge)                       收到通知  0000 0111     7           07             BEL (bell)                                       响铃 0000 1000     8           08             BS (backspace)                             退格  0000 1001     9           09             HT (horizontal tab)                         水平制表符  0000 1010     10         0A             LF (NL line feed, new line)             换行键  0000 1011     11         0B             VT (vertical tab)                             垂直制表符  0000 1100     12         0C             FF (NP form feed, new page)         换页键  0000 1101     13         0D             CR (carriage return)                       回车键 0000 1110     14         0E             SO (shift out)                                 不用切换  0000 1111     15         0F             SI (shift in)                                     启用切换  0001 0000     16         10             DLE (data link escape)                   数据链路转义  0001 0001     17         11             DC1 (device control 1)                   设备控制1  0001 0010     18         12             DC2 (device control 2)                   设备控制2  0001 0011     19         13             DC3 (device control 3)                   设备控制3  0001 0100     20         14             DC4 (device control 4)                   设备控制4  0001 0101     21         15             NAK (negative acknowledge)         拒绝接收  0001 0110     22         16             SYN (synchronous idle)                 同步空闲  0001 0111     23         17             ETB (end of trans. block)               传输块结束  0001 1000     24         18             CAN (cancel)                                 取消 0001 1001     25         19             EM (end of medium)                       介质中断  0001 1010     26         1A             SUB (substitute)                             替补  0001 1011     27         1B             ESC (escape)                                 溢出  0001 1100     28         1C             FS (file separator)                         文件分割符  0001 1101     29         1D             GS (group separator)                     分组符  0001 1110     30         1E             RS (record separator)                   记录分离符  0001 1111     31         1F             US (unit separator)                         单元分隔符
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值