从零开始的leetcode刷题——第5题


int check(int front,int rear,int size,char* s){

    if( front-rear+1 <= size ) return 0;

    while ( rear<=front ){

        if( s[rear] != s[front] )
            break;

        rear++;
        front--;
    }


    if(rear >front) return 1;

    return 0;
}

char* longestPalindrome(char* s) {
    int front,rear;
    char *p;
    int len=strlen(s);
    int size=0;

    p=(char*)malloc(1001*sizeof(char));

    if(len==0||len==1) return s;

    rear=0;
    front=len-1;

    while(rear<=len-1){

        front=len-1;

        if( front-rear+1 <= size ) break;

        while(rear<=front){

            if( front-rear+1 <= size ) break;

            if(s[rear] == s[front]){

                if( check(front,rear,size,s) ) {

                    strcpy(p,&s[rear]);

                    p[front-rear+1]='\0';

                    front--;

                    size=front-rear+1;
                    break;
                }

            }
            front--;

        }

        rear++;
    }

    return p;
}

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值