C语言 指针问题

1.数组分区(指针作为函数参数)本题由三个部分构成(1)编写一个函数CountEvensAndOdds,其功能是统计一个整型数组中奇数和偶数的个数。该函数有4个参数,整数... 1. 数组分区(指针作为函数参数)
本题由三个部分构成
(1) 编写一个函数CountEvensAndOdds,其功能是统计一个整型数组中奇数和偶数的个数。该函数有4个参数,整数型数组、数组的长度和两个指针(用于返回奇数、偶数的个数)
(2) 利用(1)中的CountEvensAndOdds函数,编写一个Partition函数,其功能是找出给定长度的一个整型数组中的所有奇数和偶数,并把它们分别保存在两个新的整型数组中(用C语言的库函数malloc函数动态创建),然后返回这两个新数组及其长度。该函数的参数有6个,整型数组、数组长度、奇数数组及其长度、偶数数组及其长度。
(3) 编写主函数,要求能够定义一个数组,并能够用随机数对该数组进行初始化,然后调用(2)中的函数Partition,将原始数组、奇数数组、偶数数组输出。
展开
 我来答
彭珂的课堂
2021-05-29 · IT资讯、技能教学、学习经验分享。
彭珂的课堂
采纳数:98 获赞数:343

向TA提问 私信TA
展开全部

C语言_071_指针的定义和使用_上

已赞过 已踩过<
你对这个回答的评价是?
评论 收起
TableDI
2024-07-18 广告
VLOOKUP是Excel中用于垂直查找的函数,其基本用法包括四个参数:1. 查找值:即在数据表首列中需要搜索的值。2. 数据表:包含查找值的单元格区域或数组。3. 返回值所在列数:指定返回查询区域中第几列的值。4. 查找方式:选择精确匹配... 点击进入详情页
本回答由TableDI提供
求知一人
2013-11-30 · 超过47用户采纳过TA的回答
知道小有建树答主
回答量:106
采纳率:0%
帮助的人:71万
展开全部
#include <stdio.h>
#include <stdlib.h>
#include <process.h>
void CountEvensAndOdds(int *parr,int arr_len,
int *even_count,int *odds_count) {
int i;
int count_even = 0;
int count_odds = 0;

for ( i=0; i<arr_len; i++ ) {
if ( (*(parr+i)%2) == 0 )
count_even++;
else
count_odds++;
}
*even_count = count_even;
*odds_count = count_odds;
}
void Partition(int *parr,int arr_len,
int **even_arr,int *even_len,
int **odds_arr,int *odds_len) {

int even_count;
int odds_count;
int i;
int m = 0,n = 0;
int count_even = 0;
int count_odds = 0;

CountEvensAndOdds(parr,arr_len,&even_count,&odds_count);

*even_arr = (int *)malloc(sizeof(int)*even_count);
*odds_arr = (int *)malloc(sizeof(int)*odds_count);

for ( i=0; i<arr_len; i++ ) {
if ( (*(parr+i)%2) == 0 ) {
*(*even_arr+m) = *(parr+i);
m++;
}
else {
*(*odds_arr+n) = *(parr+i);
n++;
}

}

*even_len = m;
*odds_len = n;
}
void print_arr(int *parr,int arr_len) {
int i;
for ( i=0; i<arr_len; i++ )
printf("%d ",*(parr+i));
printf("\n");
}
int main () {
int *parr;
int arr_len;
int i;
int *even_arr;
int even_len;
int *odds_arr;
int odds_len;

srand(getpid());

arr_len = rand()%100;
parr = (int *)malloc(sizeof(int) *arr_len);

printf("arr_len = %d \n",arr_len);
for ( i=0; i<arr_len; i++ ) {
parr[i] = rand()%100;
}
Partition(parr,arr_len,&even_arr,&even_len,&odds_arr,&odds_len);
printf("arr:\n");
print_arr(parr,arr_len);
printf("even_arr len = %d\n",even_len);
printf("even_arr:\n");
print_arr(even_arr,even_len);
printf("odds_arr len = %d\n",odds_len);
printf("odds_arr:\n");
print_arr(odds_arr,odds_len);
return 0;
}
本回答被提问者采纳
已赞过 已踩过<
你对这个回答的评价是?
评论 收起
收起 1条折叠回答
推荐律师服务: 若未解决您的问题,请您详细描述您的问题,通过百度律临进行免费专业咨询

为你推荐:

下载百度知道APP,抢鲜体验
使用百度知道APP,立即抢鲜体验。你的手机镜头里或许有别人想知道的答案。
扫描二维码下载
×

类别

我们会通过消息、邮箱等方式尽快将举报结果通知您。

说明

0/200

提交
取消

辅 助

模 式