- c - 在位数组中找到第一个零
- linux - Unix 显示有关匹配两种模式之一的文件的信息
- 正则表达式替换多个文件
- linux - 隐藏来自 xtrace 的命令
在程序开始时,我为一个字符指针数组分配了内存:
char **buffer = calloc( 20, sizeof(char *) );
然后用户最多可以输入 20 个单词:
buffer[i] = calloc( 40, sizeof(char) );
fgets( buffer[i], 40, stdin )`
然后我想对这个数组进行排序。如果我按如下方式使用我的交换功能,它会按预期工作:
void swap(char *args1, char *args2) {
char tmp[40];
strcpy( tmp, args1 );
strcpy( args1, args2 );
strcpy( args2, tmp );
}
void sort( char **args, int count ) {
...
swap( args[i], args[j] );
...
}
经过深思熟虑后,我注意到这是对 CPU 的浪费,因为我所要做的实际上是将指针重定向到相应的字符串。所以我重写了我的交换函数:
void swap(char **args1, char **args2) {
char *tmp = *args1;
*args1 = *args2;
*args2 = tmp;
}
void sort( char **args, int count ) {
...
swap( &args[i], &args[j] );
...
}
然而,这根本行不通,结果非常出乎意料,我不明白为什么(我尝试了几次 printf 调用等等)...我的理解是指针只是被重定向并因此被交换,比方说内存看起来像这样:
(begin of char**):
100: *160
108: *200
116: *240
124: *280
...
(begin of char*):
160: Hello!\0
200: World!\0
...
我的想法是更改指针而不是数组,以尽量减少 CPU 工作量(此处:将 100 中的指针与 108 中的指针交换):
(begin of char**):
100: *200
108: *160
116: *240
124: *280
...
(begin of char*):
160: Hello!\0
200: World!\0
...
我已尽力解释清楚,如果解释太多,我深表歉意。如果有人能让我对此有所了解并提供帮助,我将非常高兴!
完整代码(带有工作 strcpy)可以在这里找到:http://pastie.org/5361481
最佳答案
您的排序函数最终应如下所示:
void sort(char ** args, const int start, const int end) {
char **pivot = &args[end];
int i = start-1, j = start;
while( j < end ) {
int cmp = strcmp( *pivot, args[j] );
if( cmp > 0 )
swap( &args[++i], &args[j] );
j++;
}
swap( &args[++i], pivot );
if( start + 1 < i )
sort( args, start, i - 1 );
if( end - 1 > i )
sort( args, i + 1, end );
}
我怀疑您没有将主元设为 char**
,而是将其保留为 char*
。如果这样做,那么无论何时进行交换,实际上都不是在交换数组中的两个元素,而是用局部变量交换数组中的一个元素。枢轴变量最终指向不同的字符串,而不是最后一个数组成员指向不同的字符串。
关于c - 在 C : swapping pointers leads to unexpected results 中排序,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/13333710/
我的问题很简单。执行以下操作是否安全? 不需要任何道德建议,例如“不要将函数命名为 swap()!”或者随便什么,拜托! file1.hpp //header guards here #include
我很好奇,所以我检查了swap的源代码! clojure 存储库上的函数,如下所示: (defn swap! "Atomically swaps the value of atom to be:
我正在实现一个与 std::array 具有类似接口(interface)的类,它同时具有 member swap()和 non-member swap() . 由于我希望我的类模仿标准容器,因此我想
这个问题在这里已经有了答案: Rationale behind member function swap (1 个回答) 关闭 4 年前。 如果Coll是标准容器类型,a和b是Coll的实例;那么,
int a=5; b=7; int *pa=&a, *pb=&b; 交换 a 和 b 的值与交换指针的值有何不同,即 pa和 pb (不是 *pa 和 *pb )?两种情况下的结果不一样吗? 我们什么
好的,这是程序,绝对正确 #include using namespace std; template void Swap(T &a , T &b); int main(){ int i
std::swap() 函数是否可以在具有各种不同对象作为变量成员的类中正常工作?特别是,如果其中一些成员是智能指针? class test { ... std::shared_ptr
我正在尝试实现 copy-and-swap idiom在我的自定义 Matrix 类中,我按照链接问题中建议的方式执行 swap() 时遇到了一些麻烦: (我使用的编译器是MS VS2010 IDE的
我知道 ADL 是什么,我知道在 C++ 中,内部作用域函数隐藏外部作用域函数。也就是说,名称不会跨范围重载。所以函数重载需要在相同的范围内完成。 现在我的问题是,对于这个通用代码片段: #inclu
给定两个 std::vector v1, v2。 我想知道使用 std::swap(v1, v2) 比 v1.swap(v2) 有什么好处。 我已经实现了一个关于性能观点的简单测试代码(我不确定它是否
std::string 有一个成员函数 swap,这是交换两个大字符串的有效方法。 既然我们有了 move 语义,那么,给定两个大字符串 s1 和 s2,以下代码 s1.swap(s2); 在效率方面
同时使用 copy-and-swap idiom在一个具有常量引用作为成员的类中, 出现上述错误。 示例代码: #include #include using std::reference_wra
背景 考虑以下代码: #include namespace ns { struct foo { foo() : i(0) {} int i;
我们有: vector f(int); vector v; 这个有效: f(x).swap(v); 这不是: v.swap(f(x)); 为什么? 最佳答案 swap()对 vector 进行非常量引
我已在 Azure 中配置了一个生产和暂存槽,每个槽都使用自己的 SQL Azure 数据库。 每个连接字符串都配置为“粘性”。 但是,当我将生产槽(目标)与暂存槽(源)交换时,我收到以下警告。 这条
我有以下代码: char swap(char reg, char* mem) { std::swap(reg, *mem); return reg; } 我希望这可以编译为: swap
我使用 xor-swap 的插入排序不工作,但没有 xor-swap 它工作正常。如何修复我的异或交换插入排序算法? 没有异或交换的插入排序 - //sorts the given array in
关闭。这个问题是not reproducible or was caused by typos .它目前不接受答案。 这个问题是由于错别字或无法再重现的问题引起的。虽然类似的问题可能是on-topi
我正在实现 copy-and-swap idiom对于我设计的一个小型非拥有内存引用对象的 operator=。当 MemRef 引用我信任其生命周期的一 block 缓冲区时,_ptr 指向缓冲区,
我有两个问题,第二个是可选的。首先,在下面的程序(一个简单的卡片程序的原型(prototype))中,我得到以下错误: (29): error C2660: 'shuffle' : function
我是一名优秀的程序员,十分优秀!