洛谷题B3882:求回文数【双指针】

很早之前就做过这个题,不过是按照下面的方法①做的,没有学习并且深度剖析出双指针的知识点,偶然遇到重新做了一遍

题目来源:

B3882 信息与未来 2015 求回文数 - 洛谷https://www.luogu.com.cn/problem/B3882

解析方法:

①把函数里面的整数的每一位都拆进数组里面,逆序并且乘10输出和原数比较大小

②将函数里面的整数转换成字符串,使用双指针一个从前往后,一个从后往前的遍历,比较,看看是不是左指针和右指针每次指向的元素大小都一样

可执行代码:

cpp 复制代码
//把函数里面的整数的每一位都拆进数组里面,逆序并且乘10输出和原数比较大小
#include<bits/stdc++.h>
using namespace std;
int n,ans=9;
bool shi(int p){
    int ret=0,q=p;
    vector<int> a;
    while(q){
        a.push_back(q%10);
        q/=10;
    }
    for(vector<int>::iterator it=a.begin();it!=a.end();it++){
        ret=ret*10+(*it);
    }
    if(ret==p) return true;
    else return false;
}
int main(){
    cin>>n;
    for(int i=11;i<=n;i++){
        if(shi(i)) ans++;
    }    
    cout<<ans;
    return 0;
}

//将函数里面的整数转换成字符串,使用双指针一个从前往后,一个从后往前的遍历,比较,看看是不是左指针和右指针每次指向的元素大小都一样
#include<bits/stdc++.h>
using namespace std;
int n,ans=9;
bool shi(int p){
    string st=to_string(p);
    int l=0,r=st.size()-1;
    while(l<r){
        if(st[l]==st[r]){
            l++;
            r--;
        }else break;
    }
    if(l>=r) return true;
    else return false;
}
int main(){
    cin>>n;
    for(int i=11;i<=n;i++){
        if(shi(i)) ans++;
    }    
    cout<<ans;
    return 0;
}
相关推荐
yuan1999715 分钟前
欧拉梁静力与屈曲计算的 MATLAB 实现(有限差分法 + 解析解)
开发语言·算法·matlab
汉克老师1 小时前
GESP7级C++考试语法知识(二、指数函数(3、综合练习)
c++·算法·数学建模·指数函数·gesp7级·复利
林间码客2 小时前
04 ROC曲线与AUC:从零开始手动计算
大数据·人工智能·算法
Irissgwe2 小时前
map/set/multimap/multiset 的底层逻辑与实现
数据结构·c++·算法·二叉树·stl·c·红黑树
IronMurphy2 小时前
【算法五十八】23. 合并 K 个升序链表
数据结构·算法·链表
思茂信息2 小时前
CST软件基于液态金属开关的方向图可重构天线
服务器·算法·重构·cst·仿真软件·电磁仿真
月疯2 小时前
PPG研究中暑的算法记录
算法
春日见3 小时前
vscode的AI编程插件推荐:
大数据·ide·vscode·算法·机器学习·编辑器·ai编程
blxr_3 小时前
力扣hot100路径总和Ⅲhttps://leetcode.cn/problems/path-sum-iii/
算法·leetcode·职场和发展
noipp3 小时前
【无标题】
c语言·数据结构·c++·算法