gpt4 book ai didi

c - 对同一数组的两个不同部分进行排序 C

转载 作者:太空宇宙 更新时间:2023-11-04 01:56:13 24 4
gpt4 key购买 nike

我一直在玩,我已经完成了一个玩彩票的程序 (EuroMillions),而且我能够做到。

我有四个数组,两个用于数字,两个用于星星,然后我对两者进行排序,以便更轻松地比较它们。

所以这是我的问题,我可以只对前五个数字排序,然后对最后两个数字分别排序吗?或者我真的需要像以前那样拥有四个数组吗?

我用来排序的:

int cmpfunc (const void * a, const void * b)
{
return ( *(int*)a - *(int*)b );
}

qsort(b, 7, sizeof(int), cmpfunc);

如果需要代码,我可以发布它,但它相当大。

最佳答案

如果 b 是一个包含 7 个元素的 int 数组,你可以这样做

qsort(b, 5, sizeof(int), cmpfunc); // sort 5 elements starting from b 
qsort(b + 5, 2, sizeof(int), cmpfunc); // sort 2 elements starting from b+5

在每种情况下,前 2 个参数是指向内存块开始的指针和元素的数量。

所以如果b定义为

int b[] = {8, 2, 12, 4, 5, 7, 6};

你会得到

{2, 4, 5, 8, 12, 6,7}

关于c - 对同一数组的两个不同部分进行排序 C,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/33943403/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com