算法 Tips

头文件

/* 万能头文件 */
#include <bits/stdc++.h>
/* sort()、swap()、reverse()、max()、max_element() */
#include <algorithm.h>
/* INT_MAX、LONG_MAX */
#include <limits.h>
/* pow() */
#include <cmath.h>

sort 从大到小排序

// 匿名函数
sort(stus.begin(), stus.end(), [](Student& x, Student& y) {
	return x.age > y.age;
});

// cmp 函数
bool cmp (Student& x, Student& y) {
	return x.age > y.age;
}
sort(stus.begin(), stus.end(), cmp);

// cmp 结构体
struct cmp {
	bool operator()(const Student& x, const Student& y) {
		return x.age > y.age;
	}
};
sort(stus.begin(), stus.end(), cmp());

priority_queue 从大到小排序

// 匿名函数
auto cmp = [](Student& x, Student& y) {
	return x.age > y.age;
};
priority_queue<Student, vector<Student>, decltype(cmp)> pq(cmp);

// cmp 结构体
struct cmp {
	bool operator()(Student& x, Student& y) {
		return x.age < y.age;
	}
};
priority_queue<Student, vector<Student>, cmp> pq;

将字符串按点划分为不同部分并获取数字

string str = "192.168.1.31";
int pos = 0;
while ((pos = str.find('.', 0)) != string::npos) {
	cout << stoi(line.substr(0, pos)) << endl;
	str.erase(0, pos + 1);
}
cout << stoi(line.substr(0, pos)) << endl;

按行获取数据

string line;
while (getline(cin, line)) {
    int pos = 0;
    while ((pos = line.find(' ')) != string::npos) {
        cout << stoi(line.substr(0, pos)) << endl;
        line.erase(0, pos + 1);
    }
    cout << stoi(line.substr(0, pos)) << endl << endl;
}

将 8 进制变为 16 进制

string eightToTen(string eight) {
    int ten;
    int len = eight.size();
    for (int i = 0; i < len; ++i) {
        int digit = eight[i] - '0';
        ten += digit * pow(8, len - 1 - i);
    }
    return to_string(ten);
}

string tenToHex(string s_ten) {
    int ten = stoi(s_ten);
    string Hex;
    while (ten > 0) {
        int rem = ten % 16;
        string digit;
        if (rem < 10) {
            digit = '0' + rem;
        } else {
            digit = 'A' + rem - 10;
        }
        Hex = digit + Hex;
        ten /= 16;
    }
    return Hex;
}
  • 5
    点赞
  • 8
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
模糊算法的具体实现方式取决于你希望使用的模糊逻辑系统。下面是一个基于模糊逻辑的模糊算法的简单示例,使用Python中的`scikit-fuzzy`库: 首先,你需要安装 scikit-fuzzy 库。可以使用以下命令进行安装: ```python pip install scikit-fuzzy ``` 然后,你可以使用以下代码实现一个简单的模糊算法: ```python import numpy as np import skfuzzy as fuzz # 创建输入变量 x = np.arange(0, 11, 1) x_qual = fuzz.trimf(x, [0, 0, 5]) x_serv = fuzz.trimf(x, [0, 5, 10]) # 创建输出变量 y = np.arange(0, 26, 1) y_tip = fuzz.trimf(y, [0, 13, 25]) # 创建模糊规则 rule1 = fuzz.Rule(x_qual, x_serv, y_tip) # 创建模糊控制系统 tips_ctrl = fuzz.ControlSystem([rule1]) tips = fuzz.ControlSystemSimulation(tips_ctrl) # 输入模糊变量的值 tips.input['quality'] = 6.5 tips.input['service'] = 9.8 # 运行模糊控制系统 tips.compute() # 输出模糊变量的值 print(tips.output['tip']) ``` 以上代码中,我们首先通过`trimf`函数定义了输入和输出变量的隶属函数。然后,我们创建了一个模糊规则,并将其添加到一个模糊控制系统中。接下来,我们设置输入变量的值,并使用`compute`函数运行模糊控制系统。最后,我们可以通过`output`属性获取输出变量的模糊结果。 请注意,这只是模糊算法的一个简单示例,实际应用中可能需要更多的变量和规则来建立更精确的模糊逻辑系统。你可以根据具体的需求进行进一步的调整和扩展。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

进击的小老虎丶

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值