懒猫老师-数据结构-(9)堆栈应用:表达式求值讲解
文章目录
- 题目
- 优先级表
- 表达式求值的算法
- 具体操作
- 代码: 适用于一位整数的表达式
- 注意事项
- 代码: 识别多位正数, 小数
- 思路
- 代码: 完整版, 可以识别负数
本文提供视频链接与测试数据与哦~
运行时请将数据直接粘贴到输入框中。
题目
优先级表
这个我以后再来补充吧😂
表达式求值的算法
具体操作
代码: 适用于一位整数的表达式
注意事项
1.比较栈顶元素与ch优先级时, 只有’>‘不需要读入字符ch
2.循环:
do(…){
… …
} while (ch != ‘#’ || optr.getTop() != ‘#’);
退出条件:
ch为’#’ 且 栈顶为’#’
#include <iostream>
using namespace std;const int MAX_SIZE = 100; // 栈的最大长度/* Stack类模板 */
template <class DataType>
class Stack
{
private:int size; // 栈的实际大小int top; // 栈顶DataType* data; // 指向数组的指针
public:/* 异常内部类 */class Full {};class Empty {};/* 无参构造函数 */Stack(){size = MAX_SIZE;top = -1;data = new DataType[MAX_SIZE];}/* 有参构造函数 */Stack(int size){if (size < MAX_SIZE){this->size = size;top = -1;data = new DataType[size];}else{cout << "您输入的值过大, 栈的容量最大为: " << MAX_SIZE << endl;this->size = MAX_SIZE;top = -1;data = new DataType[MAX_SIZE];}}/* 析构函数 */~Stack(){delete[] data;}/* 入栈 */void push(DataType ch){if (isFull()){throw Full();}else{top++;data[top] = ch;}}/* 出栈并返回栈顶元素 */DataType pop(){if (isEmpty()){throw Empty();}else{DataType ch = data[top];top--;return ch;}}/* 获得栈项元素(不出栈) */DataType getTop(){if (isEmpty()){throw Empty();}else{return data[top];}}/* 判断栈是否为空 */bool isEmpty(){return (top == -1);}/* 判断栈是否已满 */bool isFull(){return (top + 1 == size);}/* 将设置栈为空 */void setNull(){top = -1;}/* 从栈底到栈顶依次显示栈中的元素 */void displayStack(){if (!isEmpty()){for (int i = 0; i < top + 1; i++){cout << data[i] << " ";}cout << endl;}else{cout << "栈为空" << endl;}}
};/* 运算符之间的优先关系 (二维数组) */
char compareOperator[7][7] =
{{'>', '>', '<', '<', '<', '>', '>' },{'>', '>', '<', '<', '<', '>', '>' },{'>', '>', '>', '>', '<', '>', '>' },{'>', '>', '>', '>', '<', '>', '>' },{'<', '<', '<', '<', '<', '=', '0' },{'>', '>', '>', '>', '0', '>', '>' },{'<', '<', '<', '<', '<', '0', '=' },
};/*precede()函数功能: 比较两个运算符的优先级参数: a, b中存放待比较的运算符返回char类型: 返回'>'表示a > b,返回'0'表示不可能出现的比较例如: 表达式 precede('#', '*')的值是'<'
*/
char precede(char a, char b)
{int first = -1;int last = -1;switch (a){case '+': first = 0;break;case '-': first = 1;break;case '*': first = 2;break;case '/': first = 3;break;case '(': first = 4;break;case ')': first = 5;break;case '#': first = 6;break;default: first = -1;break;}switch (b){case '+': last = 0;break;case '-': last = 1;break;case '*': last = 2;break;case '/': last = 3;break;case '(': last = 4;break;case ')': last = 5;break;case '#': last = 6;break;default: last = -1;break;}if (first == -1 || last == -1){return '0'; // 返回'0'表示不可能出现的比较}else{return compareOperator[first][last];}
}/*operate()函数功能: 进行实际的运算参数: a, b中分别以整数的形式存放两个待运算的操作数theta中存放代表燥作符的字符返回值: 运算结果以double的形式返回例如: 表达式 operate(7,'-', 2)的值是5
*/
double operate(double a, char theta, double b)
{double result = 0;switch (theta){case '+':result = a + b;break;case '-':result = a - b;break;case '*':result = a * b;break;case '/':result = a / b;break;default: cout << "您的输入有误!" << endl;exit(EXIT_FAILURE);break;}return result;
}/*isOpnd函数功能: 判断字符是否是操作数参数: c传入一个字符返回值: 如果字符c是操作数则返回真, 否则返回假
*/
bool isOpnd(char c)
{return (c >= '0' && c <= '9');
}/*isOptr函数功能: 判断字符是否是运算符参数: c传入一个字符返回值: 如果字符c是运算符则返回真, 否则返回假
*/
bool isOptr(char c)
{return (c == '+' || c == '-' || c == '*' || c == '/'|| c == '(' || c == ')' || c == '#');
}/*EvaluateExpression函数功能: 进行表达式计算参数: 无返回值: 返回double型的运算结果, 如果出现异常情况, 终止程序程序过程: 分别定义
*/
double EvaluateExpression()
{Stack<double> opnd; // 定义操作数栈Stack<char> optr; // 定义运算符栈optr.setNull();opnd.setNull();optr.push('#');char ch;cin >> ch;do{if (isOptr(ch)) // 如果是运算符{switch (precede(optr.getTop(), ch)) // 比较栈顶元素和ch的优先关系{case '<':optr.push(ch); // 栈顶元素优先级低, 则压入操作符栈cin >> ch;break;case '=':if (ch == ')'){optr.pop(); // 消去一对括号}cin >> ch;break;case '>': // 栈顶元素优先级高,取出一个运算符,两个操作数,并计算char theta = optr.pop();double b = opnd.pop();double a = opnd.pop();opnd.push(operate(a, theta, b)); // 将计算结果压入操作数栈break;}}else if (isOpnd(ch)) // 如果是操作数{int temp = ch - '0'; // 将字符ch转换为数字 (可以用int来接受)opnd.push(temp); // 将temp压入操作数栈cin >> ch;}} while (ch != '#' || optr.getTop() != '#');return opnd.getTop();
}int main()
{cout << "请输入一个正整数表达式, 可以输入的字符包括 +-*/()#0123456789" << endl;double result = EvaluateExpression();cout << "计算结果是: " << result << endl;return 0;
}/* 测试数据:
1+3/2-9/(4-1)# -0.5
2+3*4*(5-2)+6# 44
(4+2)*(3-2)/5# 1.2
*/
代码: 识别多位正数, 小数
思路
先声明处理多位数和小数的变量bits: double bits = 0;
则输入字符ch时:
若ch为数字 ch >= '0' && ch <= '9'
-
为一位整数: 条件是bits为0
处理方法:
opnd.push(numCh);
bits++;
-
小数: 条件是0<bits<=1
处理方法:
double sum = opnd.pop() + numCh * bits;
bits *= 0.1;
opnd.push(sum);
-
多位整数: 条件是bits>=1
处理方法:
double sum = opnd.pop() * 10 + numCh;
opnd.push(sum);
-
出错
若ch为运算符, 就令bits为0
(遇到符号, 则不是数字了, 将位数清空)
若ch为小数点, 且小数点前面必须为数字(如: 1.2可以, 但*.2和1.2.3不行), 令bits为0.1就可以了。
#include <iostream>
using namespace std;const int MAX_SIZE = 100; // 栈的最大长度/* Stack类模板 */
template <class DataType>
class Stack
{
private:int size; // 栈的实际大小int top; // 栈顶DataType* data; // 指向数组的指针
public:/* 异常内部类 */class Full {};class Empty {};/* 无参构造函数 */Stack(){size = MAX_SIZE;top = -1;data = new DataType[MAX_SIZE];}/* 有参构造函数 */Stack(int size){if (size < MAX_SIZE){this->size = size;top = -1;data = new DataType[size];}else{cout << "您输入的值过大, 栈的容量最大为: " << MAX_SIZE << endl;this->size = MAX_SIZE;top = -1;data = new DataType[MAX_SIZE];}}/* 析构函数 */~Stack(){delete[] data;}/* 入栈 */void push(DataType ch){if (isFull()){throw Full();}else{top++;data[top] = ch;}}/* 出栈并返回栈顶元素 */DataType pop(){if (isEmpty()){throw Empty();}else{DataType ch = data[top];top--;return ch;}}/* 获得栈项元素(不出栈) */DataType getTop(){if (isEmpty()){throw Empty();}else{return data[top];}}/* 判断栈是否为空 */bool isEmpty(){return (top == -1);}/* 判断栈是否已满 */bool isFull(){return (top + 1 == size);}/* 将设置栈为空 */void setNull(){top = -1;}/* 从栈底到栈顶依次显示栈中的元素 */void displayStack(){if (!isEmpty()){for (int i = 0; i < top + 1; i++){cout << data[i] << " ";}cout << endl;}else{cout << "栈为空" << endl;}}
};/* 运算符之间的优先关系 (二维数组) */
char compareOperator[7][7] =
{{'>', '>', '<', '<', '<', '>', '>' },{'>', '>', '<', '<', '<', '>', '>' },{'>', '>', '>', '>', '<', '>', '>' },{'>', '>', '>', '>', '<', '>', '>' },{'<', '<', '<', '<', '<', '=', '0' },{'>', '>', '>', '>', '0', '>', '>' },{'<', '<', '<', '<', '<', '0', '=' },
};/*precede()函数功能: 比较两个运算符的优先级参数: a, b中存放待比较的运算符返回char类型: 返回'>'表示a > b,返回'0'表示不可能出现的比较例如: 表达式 precede('#', '*')的值是'<'
*/
char precede(char a, char b)
{int first = -1;int last = -1;switch (a){case '+': first = 0;break;case '-': first = 1;break;case '*': first = 2;break;case '/': first = 3;break;case '(': first = 4;break;case ')': first = 5;break;case '#': first = 6;break;default: first = -1;break;}switch (b){case '+': last = 0;break;case '-': last = 1;break;case '*': last = 2;break;case '/': last = 3;break;case '(': last = 4;break;case ')': last = 5;break;case '#': last = 6;break;default: last = -1;break;}if (first == -1 || last == -1){return '0'; // 返回'0'表示不可能出现的比较}else{return compareOperator[first][last];}
}/*operate()函数功能: 进行实际的运算参数: a, b中分别以整数的形式存放两个待运算的操作数theta中存放代表燥作符的字符返回值: 运算结果以double的形式返回例如: 表达式 operate(7,'-', 2)的值是5
*/
double operate(double a, char theta, double b)
{double result = -1;switch (theta){case '+':result = a + b;break;case '-':result = a - b;break;case '*':result = a * b;break;case '/':result = a / b;break;default: cout << "您的输入有误!" << endl;exit(EXIT_FAILURE);break;}return result;
}/*isOpnd函数功能: 判断字符是否是操作数参数: c传入一个字符返回值: 如果字符c是操作数则返回真, 否则返回假
*/
bool isOpnd(char c)
{return (c >= '0' && c <= '9');
}/*isOptr函数功能: 判断字符是否是运算符参数: c传入一个字符返回值: 如果字符c是运算符则返回真, 否则返回假
*/
bool isOptr(char c)
{return (c == '+' || c == '-' || c == '*' || c == '/'|| c == '(' || c == ')' || c == '#');
}/*EvaluateExpression函数功能: 进行表达式计算参数: 无返回值: 返回double型的运算结果, 如果出现异常情况, 终止程序
*/
double EvaluateExpression()
{Stack<double> opnd; // 定义操作数栈Stack<char> optr; // 定义运算符栈optr.setNull();opnd.setNull();optr.push('#');double bits = 0; // 表示数字的位数char ch;cin >> ch;do{if (ch == ' '){cin >> ch;}else if (ch == '.' && bits >= 1) // 小数点前面必须为数字!(如: 1.2可以, *.2不可以){bits = 0.1;cin >> ch;}else if (isOptr(ch)) // 如果是运算符{bits = 0; // 遇到符号, 则不是数字了, 将位数清空switch (precede(optr.getTop(), ch)) // 比较栈顶元素和ch的优先关系{case '<':optr.push(ch); // 栈顶元素优先级低, 则压入操作符栈cin >> ch;break;case '=':if (ch == ')'){optr.pop(); // 消去一对括号}cin >> ch;break;case '>': // 栈顶元素优先级高,取出一个运算符,两个操作数,并计算{ // 在case里面声明了变量, 要用大括号块{}把这个case内的代码括起来 !!!char theta = optr.pop();double b = opnd.pop();double a = opnd.pop();opnd.push(operate(a, theta, b)); // 将计算结果压入操作数栈break;}default: // 或者case '0': 表示程序出错, '0'表示不可能出现的比较cout << "程序出错, 您输入的表达式有误!!!" << endl;exit(EXIT_FAILURE);break;}}else if (isOpnd(ch)) // 如果是操作数{double numCh = ch - '0'; // 将字符ch转换为数字 if (bits == 0) // 一位整数{opnd.push(numCh); bits++;cin >> ch;}else if (bits > 0 && bits < 1){ // 判断小数。(但1.23.4, 再会判断1.23是否为整数, 若不是, 则报错)double sum = opnd.pop() + numCh * bits;bits *= 0.1;opnd.push(sum);cin >> ch;}else if (bits >= 1) // 识别多位整数{double sum = opnd.pop() * 10 + numCh;opnd.push(sum);cin >> ch;}else{cout << "程序出错, 您输入的表达式有误!!!" << endl;exit(EXIT_FAILURE);}}else // 如果输入的ch不是数字, 运算符, 小数点, 空格, 则输入有误, 程序终止{cout << "程序出错, 您输入的表达式有误!!!" << endl;exit(EXIT_FAILURE);}} while (ch != '#' || optr.getTop() != '#');return opnd.getTop();
}int main()
{cout << "请输入一个非负表达式, 可以输入的字符包括 +-*/()#0123456789" << endl;double result = EvaluateExpression();cout << "计算结果是: " << result << endl;return 0;
}/* 测试数据:
2+3*4*(5-2)+6# 44
2 +3 *9 # 29
23*(2+5)+62/3# 181.667
23 *4 5+2# 1037
@345+6# 错误
#34/3# 11.3333
12.25*(4.1-2.5)/(6-4.233)+4# 15.0922
(24+4)/(3.5*6/3)# 4
123*8+.23# 错误
1+2.3.3# 错误1 + 3 * 5 / 4 * 8 / 9 * 6 * 2 / 3 / 7 + 3 * 8 / 2 # 14.9048
985211*985/211# 4.59921e+06
*/
代码: 完整版, 可以识别负数
处理负号
情况:
1. 第一个字符为负号
2. 括号内的负数: str[i-1] == ‘-’;
处理方法: 0 - 正数
1. 先将0存入opnd栈
2. 再把’-‘存入optr栈
注意: 在这个代码里我把表达式的结尾的’#‘改为了’=’, 这样更加符合实际;
另外用string类型来代替每次要cin >> ch; 这样主要是为了用erase函数来删除表达式中的空格便于后续的处理。
#include <iostream>
#include <string>
using namespace std;const int MAX_SIZE = 100; // 栈的最大长度/* Stack类模板 */
template <class DataType>
class Stack
{
private:int size; // 栈的实际大小int top; // 栈顶DataType* data; // 指向数组的指针
public:/* 异常内部类 */class Full {};class Empty {};/* 无参构造函数 */Stack(){size = MAX_SIZE;top = -1;data = new DataType[MAX_SIZE];}/* 有参构造函数 */Stack(int size){if (size < MAX_SIZE){this->size = size;top = -1;data = new DataType[size];}else{cout << "您输入的值过大, 栈的容量最大为: " << MAX_SIZE << endl;this->size = MAX_SIZE;top = -1;data = new DataType[MAX_SIZE];}}/* 析构函数 */~Stack(){delete[] data;}/* 入栈 */void push(DataType ch){if (isFull()){throw Full();}else{top++;data[top] = ch;}}/* 出栈并返回栈顶元素 */DataType pop(){if (isEmpty()){throw Empty();}else{DataType ch = data[top];top--;return ch;}}/* 获得栈项元素(不出栈) */DataType getTop(){if (isEmpty()){throw Empty();}else{return data[top];}}/* 判断栈是否为空 */bool isEmpty(){return (top == -1);}/* 判断栈是否已满 */bool isFull(){return (top + 1 == size);}/* 将设置栈为空 */void setNull(){top = -1;}/* 从栈底到栈顶依次显示栈中的元素 */void displayStack(){if (!isEmpty()){for (int i = 0; i < top + 1; i++){cout << data[i] << " ";}cout << endl;}else{cout << "栈为空" << endl;}}
};/* 运算符之间的优先关系 (二维数组) */
char compareOperator[7][7] =
{{'>', '>', '<', '<', '<', '>', '>' },{'>', '>', '<', '<', '<', '>', '>' },{'>', '>', '>', '>', '<', '>', '>' },{'>', '>', '>', '>', '<', '>', '>' },{'<', '<', '<', '<', '<', '=', '0' },{'>', '>', '>', '>', '0', '>', '>' },{'<', '<', '<', '<', '<', '0', '=' },
};/*precede()函数功能: 比较两个运算符的优先级参数: a, b中存放待比较的运算符返回char类型: 返回'>'表示a > b,返回'0'表示不可能出现的比较例如: 表达式 precede('=', '*')的值是'<'
*/
char precede(char a, char b)
{int first = -1;int last = -1;switch (a){case '+': first = 0;break;case '-': first = 1;break;case '*': first = 2;break;case '/': first = 3;break;case '(': first = 4;break;case ')': first = 5;break;case '=': first = 6;break;default: first = -1;break;}switch (b){case '+': last = 0;break;case '-': last = 1;break;case '*': last = 2;break;case '/': last = 3;break;case '(': last = 4;break;case ')': last = 5;break;case '=': last = 6;break;default: last = -1;break;}if (first == -1 || last == -1){return '0'; // 返回'0'表示不可能出现的比较}else{return compareOperator[first][last];}
}/*operate()函数 例如:表达式 operate(7, '-', 2)的值是5
*/
double operate(double a, char theta, double b)
{double result = -1;switch (theta){case '+':result = a + b;break;case '-':result = a - b;break;case '*':result = a * b;break;case '/':result = a / b;break;default: cout << "您的输入有误!" << endl;exit(EXIT_FAILURE);break;}return result;
}/*EvaluateExpression函数功能: 进行表达式计算参数: 字符串返回值: 返回double型的运算结果, 如果出现异常情况, 终止程序
*/
double EvaluateExpression(string str)
{for (int i = 0; i < str.length(); i++){if (str[i] == ' '){str.erase(i, 1); // 删去所有空格i--;}}Stack<double> opnd; // 定义操作数栈Stack<char> optr; // 定义运算符栈optr.setNull();opnd.setNull();optr.push('=');double bits = 0; // 表示数字的位数int i = 0;if (str[0] == '-') // 处理第一个字符为负号的情况 {opnd.push(0);optr.push('-');i = 1;}for (; i < str.length() && (str[i] != '=' || optr.getTop() != '='); i++){if (str[i] == '.' && bits >= 1) // 小数点前面必须为数字!(但不能是此数不是小数){bits = 0.1;}else if (str[i] == '-' && str[i - 1] == '('){ // 处理括号内的负数: (-2)*(-2)opnd.push(0);optr.push('-');}else if (str[i] == '+' || str[i] == '-' || str[i] == '*' || str[i] == '/'|| str[i] == '(' || str[i] == ')' || str[i] == '='){bits = 0; // 遇到符号, 则不是数字了, 将位数清空switch (precede(optr.getTop(), str[i])) // 比较栈顶元素和ch的优先关系{case '<':optr.push(str[i]);// 栈顶元素优先级低, 则压入操作符栈break;case '=':if (str[i] == ')'){optr.pop(); // 消去一对括号}break;case '>': // 栈顶元素优先级高,取出一个运算符,两个操作数,并计算{ // 在case里面声明了变量, 要用大括号块{}把这个case内的代码括起来 !!!char theta = optr.pop();double b = opnd.pop();double a = opnd.pop();opnd.push(operate(a, theta, b)); // 将计算结果压入操作数栈i--;break;}default:cout << "程序出错, 您输入的表达式有误!!!" << endl;exit(EXIT_FAILURE);break;}}else if (str[i] >= '0' && str[i] <= '9'){double numCh = str[i] - '0'; // 将字符ch转换为数字 if (bits == 0){opnd.push(numCh);bits++;}else if (bits > 0 && bits < 1){ // 判断小数, 例如1.23.4, 会判断1.23是否为整数, 若不是, 则报错double sum = opnd.pop() + numCh * bits;bits *= 0.1;opnd.push(sum);}else if (bits >= 1){double sum = opnd.pop() * 10 + numCh;opnd.push(sum);}else{cout << "程序出错, 您输入的表达式有误!!!" << endl;exit(EXIT_FAILURE);}}else // 如果输入的ch不是数字, 运算符, 小数点, 空格, 则输入有误, 程序终止{cout << "程序出错, 您输入的表达式有误!!!" << endl;exit(EXIT_FAILURE);}}return opnd.getTop();
}int main()
{string str;cout << "请输入一个非负表达式, 可以输入的字符包括 +-*/()=0123456789" << endl;getline(cin, str);double result = EvaluateExpression(str);cout << "计算结果是: " << result << endl;return 0;
}/* 测试数据:
2+3*4*(5-2)+6= 44
2 +3 *9 = 29
23*(2+5)+62/3= 181.667
23 *4 5+2= 1037
@345+6= 错误
=34/3= 错误
12.25*(4.1-2.5)/(6-4.233)+4= 15.0922
(24+4)/(3.5*6/3)= 4
123*8+.23= 错误
1+2.3.3= 错误1 + 3 * 5 / 4 * 8 / 9 * 6 * 2 / 3 / 7 + 3 * 8 / 2 = 14.9048
985211*985/211= 4.59921e+06
*//* 处理负号情况:1. 第一个字符为负号2. 括号内的负数: str[i-1] == '-';处理方法: 0 - 正数1. 将0存入opnd栈2. 将'-'存入optr栈测试数据:-1 + ( - 2)* 2-5= -10
(-24+ 4 ) /(-3.5*6/(-3 ))*4= -11.4286
(-12.25)*(- 4.1-2.5)/(-6- 4.233)+4= -3.90091
*/
如若内容造成侵权/违法违规/事实不符,请联系编程学习网邮箱:809451989@qq.com进行投诉反馈,一经查实,立即删除!
相关文章
- Spring系列教程——10AOP概述与原理
Spring系列教程——10AOP概述与原理...
2024/4/9 2:42:49 - Nginx入门
一. Nginx介绍 1.1 引言为什么要学习Nginx客户端到底要将请求发送给哪台服务器。如果所有客户端的请求都发送给了服务器1。客户端发送的请求可能是申请动态资源的,也有申请静态资源。在搭建集群后,使用Nginx做反向代理服务器1.2 Nginx介绍Nginx是由俄罗斯人研发的,应对Rambl…...
2024/4/9 2:42:48 - 箭头函数使用与this的指向
箭头函数箭头函数与一般的函数一致,是对一般函数的简化,方便书写。格式为:(参数列表) => {}; 当参数列表中只存在一个参数时,可以将小括号省略 当函数代码块中只存在一行代码时,可以不写大括号,直接将该行代码显示出来。同时,当函数存在返回值时,直接返回要返回的变…...
2024/5/6 20:39:16 - 基于Springboot的客户关系管理系统(源码+数据库)
今天很多企业在信息化方面已经做了大量工作,收到了很好的经济效益。但是很 多企业,销售、营销和服务部门的信息化程度越来越不能适应业务发展的需要,越来 越多的企业要求提高销售、营销和服务的日常业务的自动化和科学化。这是客户关系 管理应运而生的需求基础。仔细地倾听一…...
2024/4/8 21:37:17 - Python_Twelve
函数与Lambda表达式1. 函数还记得 Python 里面“万物皆对象”么?Python 把函数也当成对象,可以从另一个函数中返回出来而去构建高阶函数,比如:参数是函数返回值是函数 函数的定义函数以def关键词开头,后接函数名和圆括号()。函数执行的代码以冒号起始,并且缩进。return […...
2024/4/26 6:00:34 - 全栈的自我修养: 0005 Java 包扫描实现和应用(Jar篇)
全栈的自我修养: 0005 Java 包扫描实现和应用(Jar篇) It’s not the altitude, it’s the attitude. 决定一切的不是高度而是态度。Table of Contents依赖的 Jar 思路 完整代码 整合后代码如果你曾经使用过 Spring, 那你已经配过 包扫描路径吧,那包扫描是怎么实现的呢?让我们…...
2024/4/27 0:19:00 - Python数据分析与可视化(二)
读取数据含有逗号分隔符文件 JSON文件 源文件含有逗号分隔符文件 本节主要讲CSV类型的文件以及如何使用Pandas库来读取CSV文件。CSV文件的简介 用Pandas来读取CSV文件CSV文件的简介 在机器学习中以逗号作为分隔符的文件很常见(CSV文件),这种类型的文件每一行都有数据,每行的…...
2024/4/17 9:32:58 - 真实IP收集及其利用方式
0x01简介 CDN:全称Content Delivery Network,即内容分发网络,其基本思路是尽可能避开互联网上有可能影响数据传输速度和稳定性的瓶颈和环节,使内容传输的更快、更稳定。通过在网络各处放置节点服务器所构成的在现有的互联网基础之上的一层智能虚拟网络,CDN系统能够实时地根…...
2024/5/1 19:08:39 - RDTWDocker Compose部署GitLab服务,搭建自己的代码
场景Docker-Compose简介与Ubuntu Server 上安装Compose:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/100902301Docker Compose基本使用-使用Compose启动Tomcat为例:https://blog.csdn.net/BADAO_LIUMANG_QIZHI/article/details/100904080Docker Compose部署项…...
2024/4/9 2:42:46 - Java-Iterator迭代器
Java Iterator(迭代器) Java Iterator(迭代器)不是一个集合,它是一种用于访问集合的方法,可用于迭代 ArrayList 和 HashSet 等集合。 迭代器 it 的两个基本操作是 next 、hasNext 和 remove。 调用 it.next() 会返回迭代器的下一个元素,并且更新迭代器的状态。 调用 it.…...
2024/5/6 19:00:27 - tensorflow学习总结(一)
学了了tensorflow 中关于函数以及Variable函数的使用,以下是相关代码以及注释。 import tensorflow as tf state=tf.Variable(0,name=variable1)#给定变量的初始值以及名字 print(state.name)#打印变量名 con=tf.constant(1,name=constant1)#常量值为1 new_value=tf.add(state…...
2024/5/1 18:06:12 - 分割与抠图的区别
今天我们的猪脚是辨别分割与抠图,这两个功能,我觉得是差不多,都是把目标物体提取出来,但它们的区别主要在哪里?1.什么是分割?分割就是做分类,但分类出的像素点,如果不去融合处理,再进行融合就不自然了。2.什么是抠图?在抠图中有一个上帝公式,“C = αF + (1-α)B”。…...
2024/4/27 8:06:44 - 【Protobuf】Protobuf入门
文章目录Protobuf入门简介序列化和反序列化XML、JSON和ProtoBufProtoBuf APIDemo Protobuf入门 简介 Protobuf全称是Google Protocol Buffer,是一种高效轻便的结构化数据存储方式,可用于(数据)通信协议、数据存储等。 也可以理解为结构化数据的序列化方法,可简单类比为XML…...
2024/4/18 6:48:50 - 【Java】this关键字理解与使用
引出this关键字 在Java中,this表示当前对象; this主要存在于两个位置: 1. 构造器中: 就表示当前创建的对象,证明代码1如下: class Person {private String name;private int age;Person(){System.out.println(this);} } class ThisDemo2 {public static void main(Strin…...
2024/4/9 2:42:42 - 两台window下创建主从同步mysql数据库
1、主库(从库MySQL版本不能低于主库版本,两台机子必须相互ping成功) 1、先下载好mysql压缩文件,然后解压-F:\mysql。 2、配置my.ini信息 [mysqld] port = 3306 server-id=1 basedir=F:\mysql datadir=F:\mysql\data binlog-do-db=testadd binlog-ignore-db=mysql log-bin=F…...
2024/4/26 22:17:58 - linux搭建svn服务器及注意问题
第一步: yum install subversion第二步: [root@localhost home]# cd /home [root@localhost home]# ls centos76 [root@localhost home]# mkdir svn [root@localhost home]# ls centos76 svn第三步: 添加仓库 [root@localhost home]# svnadmin create /home/svn/apple [roo…...
2024/4/14 2:43:30 - JAVA学习day02
JAVA学习day02day021.关键字:1.1概念1.2特点:1.3保留字1.4注意事项2.标识符:2.1概念:2.2组成规则:2.3注意事项:2.4命名规范:3.常量3.1常量的概念及分类3.2常量的表现形式3.2.1进制的分类和组成 二进制3.2.2进制之间的转换3.2.3有符号数的表示方法3.3 println和print的区别4…...
2024/4/9 2:42:37 - 2020杭电多校第二场题解1001,1006,1010,1012
1.Total Eclipse(并查集) 题目链接http://acm.hdu.edu.cn/showproblem.php?pid=6763思路很明显的对于一个连通块需要执行其中点权值最小的那个,连通块也可能分裂, 只要每次找个连通块反复删最小的权值即可,但这种情况不好实现,所以换下面这种方法 从最大权值的点倒着添加…...
2024/4/9 2:42:36 - OpenCV3 ORB特征检测与匹配 (程序实战)代码详解
ORB特征提取分为两步: ①FAST角点提取,找出图片中的角点、计算特征点的主方向为后续BRIEF描述子增加了旋转不变特性。 ②BRIEF特征点描述。 OpenCV3中ORB特征检测主要分为五步: –读取图像 –初始化 ①检测Oriented FAST角点位置 ②根据焦点位置计算BRIEF描述子 ③使用Hammi…...
2024/5/5 19:46:29 - (动态规划)矩阵连乘问题
public class MatrixQuestion {static int n; // 矩阵数量public static void MatriaxChain(int[] p, int[][] m, int[][] s) {for (int i = 0; i <= n; i++) {m[i][i] = 0;}for (int r = 2; r <= n; r++) { // 多少个矩阵相乘for (int i = 1; i <= n - r + 1; i++) {…...
2024/4/27 3:48:03
最新文章
- 关于视频号小店,常见问题解答,开店做店各方面详解
大家好,我是电商笨笨熊 视频号小店作为今年风口,一个新推出的项目,凭借着自身流量加用户群体的优势吸引了不少的电商玩家。 但对于很多玩家来说,视频号小店完全是一个新的项目、新的领域,因此也会存在很多的疑问&…...
2024/5/6 21:54:15 - 梯度消失和梯度爆炸的一些处理方法
在这里是记录一下梯度消失或梯度爆炸的一些处理技巧。全当学习总结了如有错误还请留言,在此感激不尽。 权重和梯度的更新公式如下: w w − η ⋅ ∇ w w w - \eta \cdot \nabla w ww−η⋅∇w 个人通俗的理解梯度消失就是网络模型在反向求导的时候出…...
2024/5/6 9:38:23 - Vue3学习01 Vue3核心语法
Vue3学习 1. Vue3新的特性 2. 创建Vue3工程2.1 基于 vue-cli 创建项目文件说明 2.2 基于 vite 创建具体操作项目文件说明 2.3 简单案例(vite) 3. Vue3核心语法3.1 OptionsAPI 与 CompositionAPIOptions API 弊端Composition API 优势 ⭐3.2 setup小案例setup返回值setup 与 Opt…...
2024/5/4 16:48:24 - __dirname 在ES模块中的使用
前言 ECMAScript模块是 JavaScript 的新标准格式。在Node.js中越来越多的库逐渐从从CommonJS转移到ES模块 注:这里是指“真”ES 模块并不是指代码中 Node.js 中使用 import 写法但是实际被 tsc 转成 commonJS 的形式 但是Node.js ES 开发中此前有一个棘手的问题是获…...
2024/5/5 8:47:05 - 小林coding图解计算机网络|基础篇01|TCP/IP网络模型有哪几层?
小林coding网站通道:入口 本篇文章摘抄应付面试的重点内容,详细内容还请移步: 文章目录 应用层(Application Layer)传输层(Transport Layer)TCP段(TCP Segment) 网络层(Internet Layer)IP协议的寻址能力IP协议的路由能力 数据链路层(Link Lay…...
2024/5/6 18:43:19 - 416. 分割等和子集问题(动态规划)
题目 题解 class Solution:def canPartition(self, nums: List[int]) -> bool:# badcaseif not nums:return True# 不能被2整除if sum(nums) % 2 ! 0:return False# 状态定义:dp[i][j]表示当背包容量为j,用前i个物品是否正好可以将背包填满ÿ…...
2024/5/6 18:23:10 - 【Java】ExcelWriter自适应宽度工具类(支持中文)
工具类 import org.apache.poi.ss.usermodel.Cell; import org.apache.poi.ss.usermodel.CellType; import org.apache.poi.ss.usermodel.Row; import org.apache.poi.ss.usermodel.Sheet;/*** Excel工具类** author xiaoming* date 2023/11/17 10:40*/ public class ExcelUti…...
2024/5/6 18:40:38 - Spring cloud负载均衡@LoadBalanced LoadBalancerClient
LoadBalance vs Ribbon 由于Spring cloud2020之后移除了Ribbon,直接使用Spring Cloud LoadBalancer作为客户端负载均衡组件,我们讨论Spring负载均衡以Spring Cloud2020之后版本为主,学习Spring Cloud LoadBalance,暂不讨论Ribbon…...
2024/5/5 19:59:54 - TSINGSEE青犀AI智能分析+视频监控工业园区周界安全防范方案
一、背景需求分析 在工业产业园、化工园或生产制造园区中,周界防范意义重大,对园区的安全起到重要的作用。常规的安防方式是采用人员巡查,人力投入成本大而且效率低。周界一旦被破坏或入侵,会影响园区人员和资产安全,…...
2024/5/6 7:24:07 - VB.net WebBrowser网页元素抓取分析方法
在用WebBrowser编程实现网页操作自动化时,常要分析网页Html,例如网页在加载数据时,常会显示“系统处理中,请稍候..”,我们需要在数据加载完成后才能继续下一步操作,如何抓取这个信息的网页html元素变化&…...
2024/5/5 15:25:47 - 【Objective-C】Objective-C汇总
方法定义 参考:https://www.yiibai.com/objective_c/objective_c_functions.html Objective-C编程语言中方法定义的一般形式如下 - (return_type) method_name:( argumentType1 )argumentName1 joiningArgument2:( argumentType2 )argumentName2 ... joiningArgu…...
2024/5/6 6:01:13 - 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】
👨💻博客主页:花无缺 欢迎 点赞👍 收藏⭐ 留言📝 加关注✅! 本文由 花无缺 原创 收录于专栏 【洛谷算法题】 文章目录 【洛谷算法题】P5713-洛谷团队系统【入门2分支结构】🌏题目描述🌏输入格…...
2024/5/6 7:24:06 - 【ES6.0】- 扩展运算符(...)
【ES6.0】- 扩展运算符... 文章目录 【ES6.0】- 扩展运算符...一、概述二、拷贝数组对象三、合并操作四、参数传递五、数组去重六、字符串转字符数组七、NodeList转数组八、解构变量九、打印日志十、总结 一、概述 **扩展运算符(...)**允许一个表达式在期望多个参数࿰…...
2024/5/6 1:08:53 - 摩根看好的前智能硬件头部品牌双11交易数据极度异常!——是模式创新还是饮鸩止渴?
文 | 螳螂观察 作者 | 李燃 双11狂欢已落下帷幕,各大品牌纷纷晒出优异的成绩单,摩根士丹利投资的智能硬件头部品牌凯迪仕也不例外。然而有爆料称,在自媒体平台发布霸榜各大榜单喜讯的凯迪仕智能锁,多个平台数据都表现出极度异常…...
2024/5/6 20:04:22 - Go语言常用命令详解(二)
文章目录 前言常用命令go bug示例参数说明 go doc示例参数说明 go env示例 go fix示例 go fmt示例 go generate示例 总结写在最后 前言 接着上一篇继续介绍Go语言的常用命令 常用命令 以下是一些常用的Go命令,这些命令可以帮助您在Go开发中进行编译、测试、运行和…...
2024/5/6 0:27:44 - 用欧拉路径判断图同构推出reverse合法性:1116T4
http://cplusoj.com/d/senior/p/SS231116D 假设我们要把 a a a 变成 b b b,我们在 a i a_i ai 和 a i 1 a_{i1} ai1 之间连边, b b b 同理,则 a a a 能变成 b b b 的充要条件是两图 A , B A,B A,B 同构。 必要性显然࿰…...
2024/5/6 7:24:04 - 【NGINX--1】基础知识
1、在 Debian/Ubuntu 上安装 NGINX 在 Debian 或 Ubuntu 机器上安装 NGINX 开源版。 更新已配置源的软件包信息,并安装一些有助于配置官方 NGINX 软件包仓库的软件包: apt-get update apt install -y curl gnupg2 ca-certificates lsb-release debian-…...
2024/5/6 7:24:04 - Hive默认分割符、存储格式与数据压缩
目录 1、Hive默认分割符2、Hive存储格式3、Hive数据压缩 1、Hive默认分割符 Hive创建表时指定的行受限(ROW FORMAT)配置标准HQL为: ... ROW FORMAT DELIMITED FIELDS TERMINATED BY \u0001 COLLECTION ITEMS TERMINATED BY , MAP KEYS TERMI…...
2024/5/6 19:38:16 - 【论文阅读】MAG:一种用于航天器遥测数据中有效异常检测的新方法
文章目录 摘要1 引言2 问题描述3 拟议框架4 所提出方法的细节A.数据预处理B.变量相关分析C.MAG模型D.异常分数 5 实验A.数据集和性能指标B.实验设置与平台C.结果和比较 6 结论 摘要 异常检测是保证航天器稳定性的关键。在航天器运行过程中,传感器和控制器产生大量周…...
2024/5/6 7:24:03 - --max-old-space-size=8192报错
vue项目运行时,如果经常运行慢,崩溃停止服务,报如下错误 FATAL ERROR: CALL_AND_RETRY_LAST Allocation failed - JavaScript heap out of memory 因为在 Node 中,通过JavaScript使用内存时只能使用部分内存(64位系统&…...
2024/5/5 17:03:52 - 基于深度学习的恶意软件检测
恶意软件是指恶意软件犯罪者用来感染个人计算机或整个组织的网络的软件。 它利用目标系统漏洞,例如可以被劫持的合法软件(例如浏览器或 Web 应用程序插件)中的错误。 恶意软件渗透可能会造成灾难性的后果,包括数据被盗、勒索或网…...
2024/5/6 21:25:34 - JS原型对象prototype
让我简单的为大家介绍一下原型对象prototype吧! 使用原型实现方法共享 1.构造函数通过原型分配的函数是所有对象所 共享的。 2.JavaScript 规定,每一个构造函数都有一个 prototype 属性,指向另一个对象,所以我们也称为原型对象…...
2024/5/6 7:24:02 - C++中只能有一个实例的单例类
C中只能有一个实例的单例类 前面讨论的 President 类很不错,但存在一个缺陷:无法禁止通过实例化多个对象来创建多名总统: President One, Two, Three; 由于复制构造函数是私有的,其中每个对象都是不可复制的,但您的目…...
2024/5/6 7:24:01 - python django 小程序图书借阅源码
开发工具: PyCharm,mysql5.7,微信开发者工具 技术说明: python django html 小程序 功能介绍: 用户端: 登录注册(含授权登录) 首页显示搜索图书,轮播图࿰…...
2024/5/5 17:03:21 - 电子学会C/C++编程等级考试2022年03月(一级)真题解析
C/C++等级考试(1~8级)全部真题・点这里 第1题:双精度浮点数的输入输出 输入一个双精度浮点数,保留8位小数,输出这个浮点数。 时间限制:1000 内存限制:65536输入 只有一行,一个双精度浮点数。输出 一行,保留8位小数的浮点数。样例输入 3.1415926535798932样例输出 3.1…...
2024/5/6 16:50:57 - 配置失败还原请勿关闭计算机,电脑开机屏幕上面显示,配置失败还原更改 请勿关闭计算机 开不了机 这个问题怎么办...
解析如下:1、长按电脑电源键直至关机,然后再按一次电源健重启电脑,按F8健进入安全模式2、安全模式下进入Windows系统桌面后,按住“winR”打开运行窗口,输入“services.msc”打开服务设置3、在服务界面,选中…...
2022/11/19 21:17:18 - 错误使用 reshape要执行 RESHAPE,请勿更改元素数目。
%读入6幅图像(每一幅图像的大小是564*564) f1 imread(WashingtonDC_Band1_564.tif); subplot(3,2,1),imshow(f1); f2 imread(WashingtonDC_Band2_564.tif); subplot(3,2,2),imshow(f2); f3 imread(WashingtonDC_Band3_564.tif); subplot(3,2,3),imsho…...
2022/11/19 21:17:16 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机...
win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”问题的解决方法在win7系统关机时如果有升级系统的或者其他需要会直接进入一个 等待界面,在等待界面中我们需要等待操作结束才能关机,虽然这比较麻烦,但是对系统进行配置和升级…...
2022/11/19 21:17:15 - 台式电脑显示配置100%请勿关闭计算机,“准备配置windows 请勿关闭计算机”的解决方法...
有不少用户在重装Win7系统或更新系统后会遇到“准备配置windows,请勿关闭计算机”的提示,要过很久才能进入系统,有的用户甚至几个小时也无法进入,下面就教大家这个问题的解决方法。第一种方法:我们首先在左下角的“开始…...
2022/11/19 21:17:14 - win7 正在配置 请勿关闭计算机,怎么办Win7开机显示正在配置Windows Update请勿关机...
置信有很多用户都跟小编一样遇到过这样的问题,电脑时发现开机屏幕显现“正在配置Windows Update,请勿关机”(如下图所示),而且还需求等大约5分钟才干进入系统。这是怎样回事呢?一切都是正常操作的,为什么开时机呈现“正…...
2022/11/19 21:17:13 - 准备配置windows 请勿关闭计算机 蓝屏,Win7开机总是出现提示“配置Windows请勿关机”...
Win7系统开机启动时总是出现“配置Windows请勿关机”的提示,没过几秒后电脑自动重启,每次开机都这样无法进入系统,此时碰到这种现象的用户就可以使用以下5种方法解决问题。方法一:开机按下F8,在出现的Windows高级启动选…...
2022/11/19 21:17:12 - 准备windows请勿关闭计算机要多久,windows10系统提示正在准备windows请勿关闭计算机怎么办...
有不少windows10系统用户反映说碰到这样一个情况,就是电脑提示正在准备windows请勿关闭计算机,碰到这样的问题该怎么解决呢,现在小编就给大家分享一下windows10系统提示正在准备windows请勿关闭计算机的具体第一种方法:1、2、依次…...
2022/11/19 21:17:11 - 配置 已完成 请勿关闭计算机,win7系统关机提示“配置Windows Update已完成30%请勿关闭计算机”的解决方法...
今天和大家分享一下win7系统重装了Win7旗舰版系统后,每次关机的时候桌面上都会显示一个“配置Windows Update的界面,提示请勿关闭计算机”,每次停留好几分钟才能正常关机,导致什么情况引起的呢?出现配置Windows Update…...
2022/11/19 21:17:10 - 电脑桌面一直是清理请关闭计算机,windows7一直卡在清理 请勿关闭计算机-win7清理请勿关机,win7配置更新35%不动...
只能是等着,别无他法。说是卡着如果你看硬盘灯应该在读写。如果从 Win 10 无法正常回滚,只能是考虑备份数据后重装系统了。解决来方案一:管理员运行cmd:net stop WuAuServcd %windir%ren SoftwareDistribution SDoldnet start WuA…...
2022/11/19 21:17:09 - 计算机配置更新不起,电脑提示“配置Windows Update请勿关闭计算机”怎么办?
原标题:电脑提示“配置Windows Update请勿关闭计算机”怎么办?win7系统中在开机与关闭的时候总是显示“配置windows update请勿关闭计算机”相信有不少朋友都曾遇到过一次两次还能忍但经常遇到就叫人感到心烦了遇到这种问题怎么办呢?一般的方…...
2022/11/19 21:17:08 - 计算机正在配置无法关机,关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机...
关机提示 windows7 正在配置windows 请勿关闭计算机 ,然后等了一晚上也没有关掉。现在电脑无法正常关机以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!关机提示 windows7 正在配…...
2022/11/19 21:17:05 - 钉钉提示请勿通过开发者调试模式_钉钉请勿通过开发者调试模式是真的吗好不好用...
钉钉请勿通过开发者调试模式是真的吗好不好用 更新时间:2020-04-20 22:24:19 浏览次数:729次 区域: 南阳 > 卧龙 列举网提醒您:为保障您的权益,请不要提前支付任何费用! 虚拟位置外设器!!轨迹模拟&虚拟位置外设神器 专业用于:钉钉,外勤365,红圈通,企业微信和…...
2022/11/19 21:17:05 - 配置失败还原请勿关闭计算机怎么办,win7系统出现“配置windows update失败 还原更改 请勿关闭计算机”,长时间没反应,无法进入系统的解决方案...
前几天班里有位学生电脑(windows 7系统)出问题了,具体表现是开机时一直停留在“配置windows update失败 还原更改 请勿关闭计算机”这个界面,长时间没反应,无法进入系统。这个问题原来帮其他同学也解决过,网上搜了不少资料&#x…...
2022/11/19 21:17:04 - 一个电脑无法关闭计算机你应该怎么办,电脑显示“清理请勿关闭计算机”怎么办?...
本文为你提供了3个有效解决电脑显示“清理请勿关闭计算机”问题的方法,并在最后教给你1种保护系统安全的好方法,一起来看看!电脑出现“清理请勿关闭计算机”在Windows 7(SP1)和Windows Server 2008 R2 SP1中,添加了1个新功能在“磁…...
2022/11/19 21:17:03 - 请勿关闭计算机还原更改要多久,电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机怎么办...
许多用户在长期不使用电脑的时候,开启电脑发现电脑显示:配置windows更新失败,正在还原更改,请勿关闭计算机。。.这要怎么办呢?下面小编就带着大家一起看看吧!如果能够正常进入系统,建议您暂时移…...
2022/11/19 21:17:02 - 还原更改请勿关闭计算机 要多久,配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以...
配置windows update失败 还原更改 请勿关闭计算机,电脑开机后一直显示以以下文字资料是由(历史新知网www.lishixinzhi.com)小编为大家搜集整理后发布的内容,让我们赶快一起来看一下吧!配置windows update失败 还原更改 请勿关闭计算机&#x…...
2022/11/19 21:17:01 - 电脑配置中请勿关闭计算机怎么办,准备配置windows请勿关闭计算机一直显示怎么办【图解】...
不知道大家有没有遇到过这样的一个问题,就是我们的win7系统在关机的时候,总是喜欢显示“准备配置windows,请勿关机”这样的一个页面,没有什么大碍,但是如果一直等着的话就要两个小时甚至更久都关不了机,非常…...
2022/11/19 21:17:00 - 正在准备配置请勿关闭计算机,正在准备配置windows请勿关闭计算机时间长了解决教程...
当电脑出现正在准备配置windows请勿关闭计算机时,一般是您正对windows进行升级,但是这个要是长时间没有反应,我们不能再傻等下去了。可能是电脑出了别的问题了,来看看教程的说法。正在准备配置windows请勿关闭计算机时间长了方法一…...
2022/11/19 21:16:59 - 配置失败还原请勿关闭计算机,配置Windows Update失败,还原更改请勿关闭计算机...
我们使用电脑的过程中有时会遇到这种情况,当我们打开电脑之后,发现一直停留在一个界面:“配置Windows Update失败,还原更改请勿关闭计算机”,等了许久还是无法进入系统。如果我们遇到此类问题应该如何解决呢࿰…...
2022/11/19 21:16:58 - 如何在iPhone上关闭“请勿打扰”
Apple’s “Do Not Disturb While Driving” is a potentially lifesaving iPhone feature, but it doesn’t always turn on automatically at the appropriate time. For example, you might be a passenger in a moving car, but your iPhone may think you’re the one dri…...
2022/11/19 21:16:57