|
马上注册,结交更多好友,享用更多功能^_^
您需要 登录 才可以下载或查看,没有账号?立即注册
x
# include <stdio.h>
# include <malloc.h>
# include <stdlib.h>
struct Arr
{
int * pBase; //存储的是第一个数组第一个元素的地址
int len; //数组所能容纳的最大元素的个数
int cnt; //当前数组有效元素的个数
// int increment; //自动增长因子
};
void init_arr( struct Arr *pArr, int length );//初始化
bool append_arr(struct Arr *pArr, int val );//追加
bool insert_arr(struct Arr *pArr, int pos, int val );//插入
bool delete_arr( );//删除
int get( );
bool is_empty( struct Arr *pArr );//是否为空
bool is_full( struct Arr *pArr );//是否为满
void sort_arr( );//排序
void show_arr( struct Arr *pArr );//显示
void inversion_arr( );//倒置
int main( void )
{
struct Arr arr;
init_arr( &arr, 6);
//show_arr( &arr);
//is_empty( &arr );
append_arr(&arr, 1 );
append_arr(&arr, 2 );
append_arr(&arr, 3 );
append_arr(&arr, 4 );
append_arr(&arr, 5 );
show_arr( &arr);
return 0;
}
void init_arr( struct Arr *pArr, int length )
{
pArr->pBase = (int*)malloc(sizeof( int ) * length) ;
if( NULL == pArr->pBase )
{
printf( "动态内存分陪失败\n" );
exit(-1);
}
else
{
pArr->len = length;
pArr->cnt = 0;
}
return ;
}
void show_arr(struct Arr *pArr )
{
if(is_empty( pArr ) )
{
printf( "数组为空\n" );
}
else
{
for(int i = 0; i < pArr->cnt; i++ )
printf( "%d", pArr->pBase[i] );
}
}
bool is_empty( struct Arr *pArr )
{
if( 0 == pArr->cnt )
{
return true;
}
else
{
return false;
}
}
bool is_full( struct Arr *pArr )
{
if( pArr->cnt == pArr->len )
{
return true;
}
else
{
return false;
}
}
bool append_arr(struct Arr *pArr, int val )
{
if( is_full( pArr ) )
return false;
else
{
pArr->pBase[pArr->cnt] == val;
pArr->cnt++;
return true;
}
}
各位老师我为什么我的输出不了1,2,3,4,5,而是输出的是一个地址呢?各位老师指教下谢谢了!!
|
|