目录
常用算法
正则表达式
常用算法
double c = qAbs(a),函数 qAbs() 返回 double 型数值 a 的绝对值
double max = qMax(b,c),函数 qMax() 返回两个数值中的最大值
int bn=qRound(b),返回一个与浮点数最接近的整数值(四舍五入)
int cn = qSwap(bn,cn),交换两个数的值
测试代码:
#include "widget.h"
#include <QDebug>
Widget::Widget(QWidget *parent)
: QWidget(parent)
{
double x=-98.654,y=25.98;
double result1=qAbs(x);
qDebug()<<"Result1="<<result1;
double maxresult=qMax(x,y);
qDebug()<<"maxresult="<<maxresult;
int result2=qRound(y);
qDebug()<<"result2="<<result2;
int result3=qRound(x);
qDebug()<<"reslut3="<<result3;
qSwap(x,y);
qDebug()<<endl;
qDebug()<<x<<","<<y<<endl;
}
Widget::~Widget()
{
}
结果如下:
正则表达式
正则表达式,又称规则表达式(Regular Expression,在代码中常简写为 regex,regexp或RE),是一种文本模式,包括普通字符(例如,a到z之间的字母)和特殊字符(称为”元字符“)。正则表达式使用单个字符串描述,匹配一系列某个语法规则的字符串,通常被用来检索,替换那些符合某个模式(规则)的文本。正则表达式描述一种字符串匹配的模式(pattern),可以用来检查一个串是否含有某种子串,将匹配的子串替换或者从某个串中取出符合某个条件的子串等。
正则表达式由表达式(expression),量词(quantifiers),断言(assertions)组成。
(1) 最简单的表达式是一个字符,字符集可以使用表达式如 "[AEIOU]" ,表示匹配所有的大写元音字母;使用"[^AEIOU]"表示匹配所有非元音字母,即辅音字母;连续的字符集可以使用表达式如 "[a-z]",表示匹配所有的小写英文字母。
(2) 量词说明表达式出现的次数,如 "x[1,2]"表示"x"可以至少有一个,之多有两个。
正则表达式的量词
正则表达式的断言
测试代码
#include "mainwindow.h"
#include <QDebug>
#include <regex>
#include <QString>
MainWindow::MainWindow(QWidget *parent)
: QMainWindow(parent)
{
/* 通过正则表达式匹配:手机号码
* 根据目前对手机号码规定:11位数字,其中各段有不同的编码方式:
* 前三位:网络识别号(中国移动,中国联通,中国电信)
* 后面第8位至11位为用户号码
* 中国移动:134 159 158 188
* 中国联通:130 133 189 156
*/
QString qMobileNumber="18923558899";
std::regex reg("1(3|5|8)\\d{9}$");
std::string UserTellString=qMobileNumber.toStdString();
qDebug()<<"Phone Number"<<qMobileNumber;
// 进行匹配
bool bResult=std::regex_match(UserTellString,reg);
if(!bResult)
{
qDebug()<<"MobileNumber"<<"--->Error mobile phone number";
}
else
{
qDebug()<<qMobileNumber<<"--->Right mobile phone number";
}
}
MainWindow::~MainWindow()
{
}
结果如下: