题解 | #判断一个链表是否为回文结构#

判断一个链表是否为回文结构

https://www.nowcoder.com/practice/3fed228444e740c8be66232ce8b87c2f

/**
 * struct ListNode {
 *	int val;
 *	struct ListNode *next;
 * };
 */

/**
 * 
 * @param head ListNode类 the head
 * @return bool布尔型
 */
bool isPail(struct ListNode* head ) {
    // write code here
    if(head->next==NULL) return true;
    int arr[100001]={};
    struct ListNode* tmp=head;
    int count=0;
    while(tmp!=NULL){
        arr[count++]=tmp->val;
        tmp=tmp->next;
    }
    int flag=0;
    for(int i=0;i<count/2;i++){
        if(arr[i]!=arr[count-i-1]){
            flag=1;
            break;
        }
    }
    if(flag==0) return true;
    else return false;

}

本题的几个思路:1.使用之前的链表翻转进行处理,这样只需要验证前后的一致性;

2.使用数组进行处理,由于可以随机查找,因此处理起来会更方便,但占用空间较大;

另外,这里的flag变量其实可以省略,当在循环中找到不满足直接可以return,因为这里并非要求找到一组满足的解,因此flag的存在就没有必要性。

全部评论

相关推荐

06-27 18:45
中山大学 Ruby
25届应届毕业生,来广州2个礼拜了,找不到工作,绝望了,太难过了…
应届想染班味:9爷找不到工作只能说明,太摆了或者太挑了。
点赞 评论 收藏
分享
06-15 18:44
黄淮学院 Java
Lynn012:如果是居民楼还是算了吧,看着有点野呢
点赞 评论 收藏
分享
头顶尖尖的程序员:我也是面了三四次才放平心态的。准备好自我介绍,不一定要背熟,可以记事本写下来读。全程控制语速,所有问题都先思考几秒,不要急着答,不要打断面试官说话。
点赞 评论 收藏
分享
评论
点赞
收藏
分享

创作者周榜

更多
牛客网
牛客网在线编程
牛客网题解
牛客企业服务