24小时热门版块排行榜    

查看: 894  |  回复: 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   回复  
相关版块跳转 我要订阅楼主 断点~+++ 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 295材料求调剂,一志愿武汉理工085601专硕 +4 Charlieyq 2026-03-19 4/200 2026-03-20 14:26 by 无懈可击111
[考研] 求调剂 +4 Mqqqqqq 2026-03-19 4/200 2026-03-20 14:15 by 星空星月
[考研] 274求调剂 +8 S.H1 2026-03-18 8/400 2026-03-20 11:53 by 学员8dgXkO
[考研] 290求调剂 +4 ^O^乜 2026-03-19 4/200 2026-03-20 11:51 by 学员8dgXkO
[考研] 307求调剂 +9 冷笙123 2026-03-17 9/450 2026-03-19 22:44 by 学员8dgXkO
[考研] 294求调剂材料与化工专硕 +14 陌の森林 2026-03-18 14/700 2026-03-19 22:38 by 学员8dgXkO
[考研] 0703化学调剂 ,六级已过,有科研经历 +12 曦熙兮 2026-03-15 12/600 2026-03-19 19:42 by maocaozhuxi
[考研] 288求调剂,一志愿华南理工大学071005 +5 ioodiiij 2026-03-17 5/250 2026-03-19 18:22 by zcl123
[考研] 一志愿 西北大学 ,070300化学学硕,总分287,双非一本,求调剂。 +3 晨昏线与星海 2026-03-19 3/150 2026-03-19 13:36 by houyaoxu
[考研] 一志愿福大288有机化学,求调剂 +3 小木虫200408204 2026-03-18 3/150 2026-03-19 13:31 by houyaoxu
[考研] 一志愿西南交大,求调剂 +4 材化逐梦人 2026-03-18 4/200 2026-03-18 14:22 by 007_lilei
[考研] 293求调剂 +11 zjl的号 2026-03-16 16/800 2026-03-18 08:10 by zhukairuo
[考研] 277调剂 +5 自由煎饼果子 2026-03-16 6/300 2026-03-17 19:26 by 李leezz
[考研] 301求调剂 +4 A_JiXing 2026-03-16 4/200 2026-03-17 17:32 by ruiyingmiao
[硕博家园] 湖北工业大学 生命科学与健康学院-课题组招收2026级食品/生物方向硕士 +3 1喜春8 2026-03-17 5/250 2026-03-17 17:18 by ber川cool子
[考研] 材料专硕326求调剂 +6 墨煜姒莘 2026-03-15 7/350 2026-03-17 17:10 by ruiyingmiao
[考研] 085601求调剂 +4 Du.11 2026-03-16 4/200 2026-03-17 17:08 by ruiyingmiao
[考博] 26申博 +4 八6八68 2026-03-16 4/200 2026-03-17 13:00 by 轻松不少随
[考研] [导师推荐]西南科技大学国防/材料导师推荐 +3 尖角小荷 2026-03-16 6/300 2026-03-16 23:21 by 尖角小荷
[考研] 0854控制工程 359求调剂 可跨专业 +3 626776879 2026-03-14 9/450 2026-03-16 17:42 by 626776879
信息提示
请填处理意见