- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我有以座标给出的数据。我建立了他们的类(class),这些类(class)是这样组成的:
Point2D (int x, int y)
Point3D (int z) //#include Point2D.h
Line2D (Point2D pt1, Point2D pt2)
Line3D (Point3D pt1, Point3D pt2)
现在,我应该能够根据任何过滤条件(每个类都是过滤条件),任何排序条件(
x, y, z
或它们的乘积)和排序顺序(升序或降序)对数据进行排序
std::sort
函数将其简化。
void sort(
vector<Point2D*>& point2DList,
vector<Point3D*>& point3DList,
vector<Line2D*>& line2DList,
vector<Line3D*>& line3DList,
string filterCriteria, string sortingCriteria, string sortingOrder)
{
if (filterCriteria == "Point2D")
{
for (int i = 0; i < (int)point2DList.size() - 1; i++)
{
int index = i;
for (int j = i + 1; j < point2DList.size(); j++)
{
if (sortingOrder == "ASC")
{
if ((sortingCriteria == "x-ordinate" && point2DList[index]->getX() > point2DList[j]->getX()) ||
(sortingCriteria == "y-ordinate" && point2DList[index]->getY() > point2DList[j]->getY()))
index = j;
}
else if (sortingOrder == "DSC")
{
if ((sortingCriteria == "x-ordinate" && point2DList[index]->getX() < point2DList[j]->getX()) ||
(sortingCriteria == "y-ordinate" && point2DList[index]->getY() < point2DList[j]->getY()))
index = j;
}
}
Point2D* ptr = point2DList[i];
point2DList[i] = point2DList[index];
point2DList[index] = ptr;
}
}
}
我只粘贴了涉及
Point2D
对象的算法的第一部分,我对其他3个类也应用了相同的流程。
最佳答案
据我所知,您正在使用单个sort
函数(非模板)对不同的数据结构进行排序。这不是您使通用排序功能的方式。您需要使用function templates。
其次,指向这些数据结构的原始指针的 vector 看起来不合适。 std::vector
创建/在空闲存储中动态分配其下划线数据,这意味着您无需将其每个元素都放入手动创建的内存中。如果无法避免,我建议使用smart pointers而不是原始指针。
第三,filterCriteria
,sortingOrder
和sortingCriteria
可能是 enum
s而不是std::string
。
以下是修改后的sort
函数,该函数实际上仅考虑您使用 std::sort
的要求。还要注意,我已经使用lambda functions作为自定义排序标准,您可以在此处阅读更多内容:What is a lambda expression in C++11?
// enumerations for case checking!
enum class FilterCriteria { Point2D = 0, Point3D/*, other cases*/ };
enum class SortingCriteria { x_ordinate = 0, y_ordinate };
enum class SortingOrder { ASC = 0, DSC };
void sort(
std::vector<Point2D*>& point2DList,
std::vector<Point3D*>& point3DList,
std::vector<Line2D*>& line2DList,
std::vector<Line3D*>& line3DList,
const FilterCriteria filterCriteria,
const SortingOrder sortingOrder,
const SortingCriteria sortingCriteria)
{
const auto xLessCompare = [](const Point2D* lhs, const Point2D* rhs) { return lhs->x < rhs->x; };
const auto yLessCompare = [](const Point2D* lhs, const Point2D* rhs) { return lhs->y < rhs->y; };
const auto xGreaterCompare = [](const Point2D* lhs, const Point2D* rhs) { return lhs->x > rhs->x; };
const auto yGreaterCompare = [](const Point2D* lhs, const Point2D* rhs) { return lhs->y > rhs->y; };
switch (filterCriteria)
{
case FilterCriteria::Point2D:
{
if (sortingOrder == SortingOrder::ASC)
{
if (sortingCriteria == SortingCriteria::x_ordinate)
std::sort(point2DList.begin(), point2DList.end(), xGreaterCompare);
else if (sortingCriteria == SortingCriteria::y_ordinate)
std::sort(point2DList.begin(), point2DList.end(), yGreaterCompare);
}
else if (sortingOrder == SortingOrder::DSC)
{
if (sortingCriteria == SortingCriteria::x_ordinate)
std::sort(point2DList.begin(), point2DList.end(), xLessCompare);
else if (sortingCriteria == SortingCriteria::y_ordinate)
std::sort(point2DList.begin(), point2DList.end(), yLessCompare);
}
break;
}
case FilterCriteria::Point3D: {
// ... code
break;
}
default: break;
};
}
See here for an example code onlone
关于c++ - 对不同变量的 vector 使用排序功能,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/63543686/
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: How to nest OR statements in JavaScript? 有没有办法做到这一点:
在 JavaScript 中有没有办法让一个变量总是等于一个变量?喜欢var1 = var2但是当var2更新,也是var1 . 例子 var var1 = document.getElementBy
我正在努力理解这代表什么 var1 = var2 == var3 我的猜测是这等同于: if (var2 == var3): var1 = var2 最佳答案 赋值 var1 = var2
这个问题已经有答案了: What does the PHP error message "Notice: Use of undefined constant" mean? (2 个回答) 已关闭 8
我在临时表中有几条记录,我想从每条记录中获取一个值并将其添加到一个变量中,例如 color | caption -------------------------------- re
如何将字符串转为变量(字符串变量--> $variable)? 或者用逗号分隔的变量列表然后转换为实际变量。 我有 2 个文件: 列名文件 行文件 我需要根据字符串匹配行文件中的整行,并根据列名文件命
我有一个我无法解决的基本 php 问题,我也想了解为什么! $upperValueCB = 10; $passNodeMatrixSource = 'CB'; $topValue= '$uppe
这可能吗? php $variable = $variable1 || $variable2? 如果 $variable1 为空则使用 $variable2 是否存在类似的东西? 最佳答案 PHP 5
在 Perl 5.20 中,for 循环似乎能够修改模块作用域的变量,但不能修改父作用域中的词法变量。 #!/usr/bin/env perl use strict; use warnings; ou
为什么这不起作用: var variable; variable = variable.concat(variable2); $('#lunk').append(variable) 我无法弄清楚这一点
根据我的理解,在32位机器上,指针的sizeof是32位(4字节),而在64位机器上,它是8字节。无论它们指向什么数据类型,它们都有固定的大小。我的计算机在 64 位上运行,但是当我打印包含 * 的大
例如: int a = 10; a += 1.5; 这运行得很完美,但是 a = a+1.5; 此作业表示类型不匹配:无法从 double 转换为 int。所以我的问题是:+= 运算符 和= 运算符
您好,我写了这个 MySQL 存储过程,但我一直收到这个语法错误 #1064 - You have an error in your SQL syntax; check the manual that
我试图在我的场景中显示特定的奖牌,这取决于你的高分是基于关卡的目标。 // Get Medal Colour if levelHighscore goalScore { sc
我必须维护相当古老的 Visual C++ 源代码的大型代码库。我发现代码如下: bIsOk = !!m_ptr->isOpen(some Parameters) bIsOk的数据类型是bool,is
我有一个从 MySQL 数据库中提取的动态产品列表。在 list 上有一个立即联系 按钮,我正在使用一个 jquery Modal 脚本,它会弹出一个表单。 我的问题是尝试将产品信息变量传递给该弹出窗
这个问题在这里已经有了答案: 关闭 10 年前。 Possible Duplicate: What is the difference between (type)value and type(va
jQuery Core Style Guidelines建议两种不同的方法来检查变量是否已定义。 全局变量:typeof variable === "undefined" 局部变量:variable
这个问题已经有答案了: 已关闭11 年前。 Possible Duplicate: “Variable” Variables in Javascript? 我想肯定有一种方法可以在 JavaScrip
在语句中使用多重赋值有什么优点或缺点吗?在简单的例子中 var1 = var2 = true; 赋值是从右到左的(我相信 C# 中的所有赋值都是如此,而且可能是 Java,尽管我没有检查后者)。但是,
我是一名优秀的程序员,十分优秀!