- iOS/Objective-C 元类和类别
- objective-c - -1001 错误,当 NSURLSession 通过 httpproxy 和/etc/hosts
- java - 使用网络类获取 url 地址
- ios - 推送通知中不播放声音
我有一些字符串数组。每个数组中的字符串根据相同的标准以相同的方式排序。但是,某些数组中可能缺少某些字符串,并且可能没有包含完整字符串集的数组。此外,我无法使用用于比较字符串的标准:在数组的上下文之外,我无法判断哪个字符串应该在另一个字符串之前。
我需要一种方法来生成一整套正确排序的字符串。或者当阵列没有足够的信息让我这样做时失败。
有人熟悉这种问题吗?什么是合适的算法?
例子:
A B D
A C D
无法正确排序,无法决定B和C的顺序
A B D
A B C
A C D
这有足够的信息来正确排序 ABCD。
最佳答案
我能想到的一种可能的方法,虽然可能不是最有效的:
我将用你的例子来解释:
A B D
A B C
A C D
创建一个唯一字符数组,这样你会得到(例如):
A B D C
此外,您可能应该有一个枚举来描述可能的关系
enum Type
{
Unknown = 0,
Greater = 1,
Equal = 2,
Less = 3,
}
现在,创建一个方阵,其尺寸与上述数组相同,默认为 Type.Unknown。
0 0 0 0
0 0 0 0
0 0 0 0
0 0 0 0
当您确定顺序时,您的数组将用作矩阵的索引。要明白我的意思,请看这里:
A B D C
A 0 0 0 0
B 0 0 0 0
D 0 0 0 0
C 0 0 0 0
遍历并使对角线为 Type.Equal
2 0 0 0
0 2 0 0
0 0 2 0
0 0 0 2
现在您需要填充矩阵,遍历每个输入数组并获取每个字符及其后的字符。使用这 2 个字符,在矩阵中找到每个字符的索引(使用您的数组)并更新矩阵。
for(int i=0; i<len(arr)-1; i++)
{
char c1 = arr[i], c2 = arr[i+1];
int i1,i2;
//get indices of characters in array and put in i1, and i2 respectively
matrix[i1][i2] = Type.Less;
matrix[i2][i1] = Type.Greater
}
每次在网格中分配 2 个位置,因为当一个字符小于另一个字符时,也意味着第二个字符大于第一个字符。
现在您只需一次将字符插入一个数组(链表是最简单的,稍后您会明白为什么)
每次插入 char 时,您将从返回数组的开头开始,遍历,查找第一个数组中的索引,并检查矩阵中的 Type.Greater 或 Type.Less(取决于在比较的方式上,curr char 到 array,或 array 到 current char)并在遇到与预期不同的值时插入它。
如果您在插入期间在矩阵中点击了 Type.Unknown,您知道您没有足够的信息来对这些数组进行排序,如果您点击了 Type.Equal,则可以忽略插入此字符(假设您不不想在你的结果中重复。)
然后你会输出你的返回数组
关于algorithm - 合并具有未知排序函数的数据,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/285286/
C语言sscanf()函数:从字符串中读取指定格式的数据 头文件: ?
最近,我有一个关于工作预评估的问题,即使查询了每个功能的工作原理,我也不知道如何解决。这是一个伪代码。 下面是一个名为foo()的函数,该函数将被传递一个值并返回一个值。如果将以下值传递给foo函数,
CStr 函数 返回表达式,该表达式已被转换为 String 子类型的 Variant。 CStr(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CSng 函数 返回表达式,该表达式已被转换为 Single 子类型的 Variant。 CSng(expression) expression 参数是任意有效的表达式。 说明 通常,可
CreateObject 函数 创建并返回对 Automation 对象的引用。 CreateObject(servername.typename [, location]) 参数 serv
Cos 函数 返回某个角的余弦值。 Cos(number) number 参数可以是任何将某个角表示为弧度的有效数值表达式。 说明 Cos 函数取某个角并返回直角三角形两边的比值。此比值是
CLng 函数 返回表达式,此表达式已被转换为 Long 子类型的 Variant。 CLng(expression) expression 参数是任意有效的表达式。 说明 通常,您可以使
CInt 函数 返回表达式,此表达式已被转换为 Integer 子类型的 Variant。 CInt(expression) expression 参数是任意有效的表达式。 说明 通常,可
Chr 函数 返回与指定的 ANSI 字符代码相对应的字符。 Chr(charcode) charcode 参数是可以标识字符的数字。 说明 从 0 到 31 的数字表示标准的不可打印的
CDbl 函数 返回表达式,此表达式已被转换为 Double 子类型的 Variant。 CDbl(expression) expression 参数是任意有效的表达式。 说明 通常,您可
CDate 函数 返回表达式,此表达式已被转换为 Date 子类型的 Variant。 CDate(date) date 参数是任意有效的日期表达式。 说明 IsDate 函数用于判断 d
CCur 函数 返回表达式,此表达式已被转换为 Currency 子类型的 Variant。 CCur(expression) expression 参数是任意有效的表达式。 说明 通常,
CByte 函数 返回表达式,此表达式已被转换为 Byte 子类型的 Variant。 CByte(expression) expression 参数是任意有效的表达式。 说明 通常,可以
CBool 函数 返回表达式,此表达式已转换为 Boolean 子类型的 Variant。 CBool(expression) expression 是任意有效的表达式。 说明 如果 ex
Atn 函数 返回数值的反正切值。 Atn(number) number 参数可以是任意有效的数值表达式。 说明 Atn 函数计算直角三角形两个边的比值 (number) 并返回对应角的弧
Asc 函数 返回与字符串的第一个字母对应的 ANSI 字符代码。 Asc(string) string 参数是任意有效的字符串表达式。如果 string 参数未包含字符,则将发生运行时错误。
Array 函数 返回包含数组的 Variant。 Array(arglist) arglist 参数是赋给包含在 Variant 中的数组元素的值的列表(用逗号分隔)。如果没有指定此参数,则
Abs 函数 返回数字的绝对值。 Abs(number) number 参数可以是任意有效的数值表达式。如果 number 包含 Null,则返回 Null;如果是未初始化变量,则返回 0。
FormatPercent 函数 返回表达式,此表达式已被格式化为尾随有 % 符号的百分比(乘以 100 )。 FormatPercent(expression[,NumDigitsAfterD
FormatNumber 函数 返回表达式,此表达式已被格式化为数值。 FormatNumber( expression [,NumDigitsAfterDecimal [,Inc
我是一名优秀的程序员,十分优秀!