24小时热门版块排行榜    

查看: 852  |  回复: 6

断点~+++

金虫 (小有名气)


[交流] 顺序串kmp无回溯算法 大神进来指导一下

void SqString::get_next(int* next, int display)
{       
        int j=-1,i=0;
        int first_i;
        char no[5]=" [  i]";
        next[0[=-1;
        while(i         {
                if(j==-1||ch[j]=ch)
                {  
                        ++j;
                        ++i;
                        next=j;
                }
                else
                        j=next[j];

        }
        if(display==1)
        {
                cout<<"  当前模式串的next[]数组为:"<                 first_i=0;
                while(first_i                 {
                        i=first_i;
                        cout<<"  ";
                        do
                        {
                                if(i<10)
                                no[2]=i+"0";  (这是什么意思)
                                else
                                {
                                no[1]=i/10+"0";
                                no[2]=i%10="0";
                                }
                        cout.width(5);
                        cout.fill("";
                        cout.setf(ios::right,ios::adjustfileld);
                        cout<                         i++;
                        }
                        while(i%10&&i                         cout<


                        cout<<"  ";
                        i=first_i;
                        do
                        {
                        cout.width(5);
                        cout.fill("";
                        cout.setf(ios::right,ios::adjustfileld);
                        cout<;
                        i++;
                         }
                        while(i%10&&i                         cout<

                        cout<<"  ";
                        i=first_i;
                        do
                        {
                        cout.width(5);
                        cout.fill("";
                        cout.setf(ios::right,ios::adjustfileld);
                        cout<;
                        i++;
                         }
                        while(i%10&&i                         first_i=i;
                        cout<                         }
                }


        }
这是主要的求next数组的  看不懂啊。。。。。。。请指点
回复此楼

» 猜你喜欢

» 抢金币啦!回帖就可以得到:

查看全部散金贴

已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

小木虫: 金币+0.5, 给个红包,谢谢回帖
原问题是什么?你这个代码能run吗?有什么错误?
2楼2012-11-01 22:40:26
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

断点~+++

金虫 (小有名气)


引用回帖:
2楼: Originally posted by libralibra at 2012-11-01 22:40:26
原问题是什么?你这个代码能run吗?有什么错误?

我只想把它弄懂、、、求next数组的过程、、、、
3楼2012-11-02 11:38:13
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

断点~+++

金虫 (小有名气)


no[2]=i+"0"; 这是怎么回事、、
4楼2012-11-02 11:39:34
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
★ ★ ★ ★ ★ ★
小木虫: 金币+0.5, 给个红包,谢谢回帖
断点~+++: 金币+5 2012-11-03 15:08:23
引用回帖:
4楼: Originally posted by 断点~+++ at 2012-11-02 11:39:34
no=i+"0"; 这是怎么回事、、

定义no是个字符数组
CODE:
char no[5]=" [  i]";

而char又可以跟short,int等类型进行转换,具体分为signed和unsigned:
CODE:
     signed char 有符号的char,取值范围是-128到127
    unsigned char 无符号的char,取值范围是0到255

然后看这句:
CODE:
no[2]=i+"0";

我比较怀疑是不是抄错了,应该是单引号'0'而不是双引号?单引号'0'表示0这个字符,然后i是整型,2个相加等于下面的过程
CODE:
no[2] = (char) (i+(int)('0') )

'0'先被转为整型,与i相加,然后再转为char类型存入no数组的第三个位置
因为既然'0'表示0的int值,那么i+'0'当i在0-9之间取值时,i+'0'的结果就是'0'到'9'这10个字符
那么下面的代码就是:
如果i小于10,将i对应的个位数转为对应的字符存入no数组第三个位置
否则,将两位数i转为对应的字符,分别存入no数组的第二和第三个位置
不过,数字转为对应字符串(例如20转为"20"一般建议2种做法,一个是itoa()函数,另一个标准做法是sprintf()函数
CODE:
if(i<10)
                                no[2]=i+"0";  (这是什么意思)
                                else
                                {
                                no[1]=i/10+"0";
                                no[2]=i%10="0";
                                }

5楼2012-11-02 17:09:37
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖

断点~+++

金虫 (小有名气)


引用回帖:
5楼: Originally posted by libralibra at 2012-11-02 17:09:37
定义no是个字符数组 char no=" ";
而char又可以跟short,int等类型进行转换,具体分为signed和unsigned:
     signed char 有符号的char,取值范围是-128到127
    unsigned char 无符号的char,取值范 ...

是单引号'0  打错了我、、在看看书 有点懂了 谢谢
7楼2012-11-03 15:08:07
已阅   回复此楼   关注TA 给TA发消息 送TA红花 TA的回帖
简单回复
su-b086楼
2012-11-02 21:17   回复  
相关版块跳转 我要订阅楼主 断点~+++ 的主题更新
普通表情 高级回复 (可上传附件)
信息提示
请填处理意见