![](/img/trans.png)
[英]Write a C program to arrange the numbers in an array as a series of odd and even numbers
[英]Write a C program to create new array from a given array of integers shifting all even numbers before all odd numbers
print_array(int parray[], int size)
中存在构建错误。 为什么错误列表显示:
missing type specifier - int assumed. Note: C++ does not support default-int
这是我的代码:
#include <stdio.h>
#include <stdlib.h>
int main(void)
{
int arr_size;
int a1[] = { 1, 2, 5, 3, 5, 4, 6, 9, 11 };
arr_size = sizeof(a1) / sizeof(a1[0]);
printf("Elements in original array are: ");
print_array(a1, arr_size);
int size = arr_size, index = 0;
for (int i = 0; i < size; i++) {
if (a1[i] % 2 == 0) {
int temp = a1[index];
a1[index] = a1[i];
a1[i] = temp;
index++;
}
}
printf("\nElements in new array are: ");
print_array(a1, arr_size);
}
print_array(int parray[], int size)
{
int i;
for (i = 0; i < size - 1; i++) {
printf("%d, ", parray[i]);
}
printf("%d ", parray[i]);
printf("\n");
}
C99 不允许对未预先声明的函数使用 function 调用。 它也不允许在 function 声明中省略 function 返回类型。 在 C99 之前,假定没有返回类型的函数具有返回类型 int。
因此,您需要 1)在使用之前声明 function 和 2)明确指定其返回类型为 void,因为 function 不返回任何内容。
同样在 function 中,由于以下(不清楚)循环语句,您正在使用冗余 printf 调用
for (i = 0; i < size - 1; i++) {
^^^^^^^^^^^^
由于 function 不会更改数组,因此应使用限定符const
进行声明。
数组的大小应该是size_t
类型。 它是sizeof
运算符返回的值的类型。
main 中的循环可以优化。 如果它们的索引彼此相等,则不需要交换两个元素。
这是您更新的程序。
#include <stdio.h>
void print_array( const int parray[], size_t size );
int main(void)
{
int a1[] = { 1, 2, 5, 3, 5, 4, 6, 9, 11 };
size_t arr_size = sizeof( a1 ) / sizeof( a1[0] );
printf( "Elements in original array are: " );
print_array( a1, arr_size );
for ( size_t i = 0, j = 0; i < arr_size; i++ )
{
if ( a1[i] % 2 == 0 )
{
if ( i != j )
{
int temp = a1[j];
a1[j] = a1[i];
a1[i] = temp;
}
j++;
}
}
printf( "\nElements in new array are: " );
print_array( a1, arr_size );
}
void print_array( const int parray[], size_t size )
{
for( size_t i=0; i < size; i++ )
{
printf( "%d, ", parray[i] );
}
putchar( '\n' );
}
声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.