24小时热门版块排行榜    

Znn3bq.jpeg
查看: 904  |  回复: 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   回复  
相关版块跳转 我要订阅楼主 断点~+++ 的主题更新
普通表情 高级回复 (可上传附件)
最具人气热帖推荐 [查看全部] 作者 回/看 最后发表
[考研] 一志愿211电子信息347求调剂 +3 554916 2026-04-03 4/200 2026-04-09 22:24 by 554916
[考研] 08工学 309分求调剂 +5 Yin DY 2026-04-08 5/250 2026-04-09 20:49 by bljnqdcc
[考研] 计算机类求调剂,22408-274分 +5 上岸de小虫 2026-04-09 6/300 2026-04-09 20:48 by xujun0624
[考研] 一志愿中国科学院上海有机所,有机化学356分找调剂 +11 Nadiums 2026-04-09 11/550 2026-04-09 18:04 by lijunpoly
[考研] 化学工程与技术专业一志愿哈工程 291分B区 国家级大创负责人 有一作论文 +13 Emmy~ 2026-04-09 13/650 2026-04-09 14:47 by only周
[考研] 086000生物与医药调剂 +7 awwwwwooooo 2026-04-09 7/350 2026-04-09 13:31 by 北极159263
[考研] 一志愿上海大学生物学346 +4 上海大学346调剂 2026-04-03 4/200 2026-04-09 10:52 by yiminglu
[考研] 302分求调剂 +4 凡语祈愿 2026-04-08 5/250 2026-04-08 22:03 by 土木硕士招生
[考研] 一志愿211,化学310分,本科重点双非,求调剂 +13 努力奋斗112 2026-04-08 13/650 2026-04-08 21:17 by 学员tURuqU
[考研] 280求调剂 +9 李rien 2026-04-04 9/450 2026-04-08 13:20 by lijunpoly
[考研] 电子信息346 +4 zuoshaodian 2026-04-08 4/200 2026-04-08 11:54 by zzucheup
[考研] 22408 318分求调剂 +4 勤奋的小笼包 2026-04-06 6/300 2026-04-07 15:05 by 纸鹤555
[考研] 295求调剂 +18 xndjjj 2026-04-04 19/950 2026-04-07 11:02 by wangjy2002
[考研] 求调剂 +10 chenxrlkx 2026-04-05 10/500 2026-04-06 11:31 by 猪会飞
[考研] 319求调剂 +3 handrui 2026-04-05 3/150 2026-04-06 09:33 by jp9609
[考研] 怎么删帖子啊 +3 缝曦1000 2026-04-04 3/150 2026-04-04 14:20 by 土木硕士招生
[考研] 387求调剂 +4 爱吃片豆土 2026-04-03 5/250 2026-04-04 08:10 by 岸上的一条鱼
[考研] 268求调剂 +8 你好tg 2026-04-03 9/450 2026-04-04 05:08 by gswylq
[考研] 专硕085601求调剂 +7 suyifei 2026-04-03 8/400 2026-04-03 14:00 by 欣喜777
[考研] 求调剂 +3 心想事成可 2026-04-03 3/150 2026-04-03 11:22 by wangjy2002
信息提示
请填处理意见