亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? malloc4.c

?? 簡單遺傳算法經(jīng)典例子!! SGPC: Simple Genetic Programming in C by Walter Alden Tackett and Aviram Carmi
?? C
字號:
/**************************************************************************
   File:  malloc4.c

   2,3,4 dimensional memory allocators.
   written by Xavier Bouyssounouse
***************************************************************************/
#include <stdio.h>
#include <stdlib.h>
#include "malloc4.h"

#define STOP_FLAG 1

#ifdef ANSI_FUNC

unsigned char *malloc1(
  unsigned int size
  )
#else

unsigned char *malloc1(size)
unsigned int size;
#endif
{
    char *ptr;

    if ((int)(ptr= malloc(size))% sizeof(double))
    	fprintf(stderr,"Warning: malloc returned pointer on invalid boundary.\n");
    return (unsigned char *) ptr;
}

#ifdef ANSI_FUNC

void free2(
  unsigned char **temp2
  )
#else

void free2(temp2)	
unsigned char **temp2;
#endif
/*****************************************************/
/* Frees 2D memory allocated by malloc2 or malloc2c. */	
/*****************************************************/
{			
    int i=0;

    while (temp2[i])
	free((char *) temp2[i++]);
    free((char *) temp2);
}


#ifdef ANSI_FUNC

unsigned char **malloc2(
  int n2,
  int n1
  )
#else

unsigned char **malloc2(n2,n1)
int n2,n1;
#endif
/********************************/
/* Dynamic 2D memory allocator. */
/********************************/
{
    unsigned char **temp2;
    int i;
  
    if (!(temp2 = (unsigned char **) malloc1((n2+1)*sizeof(*temp2)+sizeof(int))))
	return NULL;
    temp2[n2] = NULL;
    for (i=0; i<n2; i++)
	if (!(temp2[i] = (unsigned char *) malloc1(n1))) {
	    free2(temp2);
	    if (STOP_FLAG) 
		perror("Out of memory");
	    return (NULL);
	}
    memcpy((char *) (temp2+n2+1),(char *) (&n1),sizeof(int));
    return (temp2);
}


#ifdef ANSI_FUNC

unsigned char **malloc2c(
  int n2,
  int n1
  )
#else

unsigned char **malloc2c(n2,n1)
int n2,n1;
#endif
/*******************************************/
/* Dynamic 2D contiguous memory allocator. */
/*******************************************/
{
    unsigned char **temp2,*p;
    int i;
  
    if (!(temp2 = (unsigned char **) malloc1((n2+1)*sizeof(*temp2)+sizeof(int))))
	return NULL;
    if (!(p=(unsigned char *) malloc1(n2*n1))) {
	free((char *) temp2);
	if (STOP_FLAG) 
	    perror("Out of memory");
	return (NULL);
    }
    temp2[n2] = NULL;
    for (i=0; i<n2; i++)
	temp2[i] = p+n1*i;
    memcpy((char *) (temp2+n2+1),(char *) &n1,sizeof(int));
    return (temp2);
}


#ifdef ANSI_FUNC

void free3(
  unsigned char ***temp3
  )
#else

void free3(temp3)	
unsigned char ***temp3;
#endif
/*****************************************/
/* Frees 3D memory allocated by malloc3. */	
/*****************************************/
{			
    int i=0;

    while (temp3[i])
	free2(temp3[i++]);
    free((char *) temp3);
}


#ifdef ANSI_FUNC

unsigned char ***malloc3(
  int n3,
  int n2,
  int n1
  )
#else

unsigned char ***malloc3(n3,n2,n1)
int n3,n2,n1;
#endif
/********************************/
/* Dynamic 3D memory allocator. */
/********************************/
{
    unsigned char ***temp3;
    int i;
  
    if (!(temp3 = (unsigned char ***) malloc1((n3+1)*sizeof(**temp3))))
	return NULL;
    temp3[n3] = NULL;
    for (i=0; i<n3; i++)
	if (!(temp3[i] = malloc2(n2,n1))) {
	    free3(temp3);
	    return (NULL);
	}
    return (temp3);
}


#ifdef ANSI_FUNC

unsigned char ***malloc3c(
  int n3,
  int n2,
  int n1
  )
#else

unsigned char ***malloc3c(n3,n2,n1)
int n3,n2,n1;
#endif
/************************************************/
/* Dynamic 3D semi-contiguous memory allocator. */
/************************************************/
{
    unsigned char ***temp3;
    int i;
  
    if (!(temp3 = (unsigned char ***) malloc1((n3+1)*sizeof(**temp3))))
	return NULL;
    temp3[n3] = NULL;
    for (i=0; i<n3; i++)
	if (!(temp3[i] = malloc2c(n2,n1))) {
	    free3(temp3);
	    return (NULL);
	}
    return (temp3);
}


#ifdef ANSI_FUNC

void free4(
  unsigned char ****temp4
  )
#else

void free4(temp4)	
unsigned char ****temp4;
#endif
/*****************************************/
/* Frees 4D memory allocated by malloc4. */	
/*****************************************/
{			
    int i=0;

    while (temp4[i])
	free3(temp4[i++]);
    free((char *) temp4);
}


#ifdef ANSI_FUNC

unsigned char ****malloc4c(
  int n4,
  int n3,
  int n2,
  int n1
  )
#else

unsigned char ****malloc4c(n4,n3,n2,n1)
int n4,n3,n2,n1;
#endif
/************************************************/
/* Dynamic 4D semi-contiguous memory allocator. */
/************************************************/
{
    unsigned char ****temp4;
    int i;
  
    if (!(temp4 = (unsigned char ****) malloc1((n4+1)*sizeof(***temp4))))
	return NULL;
    temp4[n4] = NULL;
    for (i=0; i<n4; i++)
	if (!(temp4[i] = malloc3c(n3,n2,n1))) {
	    free4(temp4);
	    return (NULL);
	}
    return (temp4);
}

#ifdef ANSI_FUNC

unsigned char ****malloc4(
  int n4,
  int n3,
  int n2,
  int n1
  )
#else

unsigned char ****malloc4(n4,n3,n2,n1)
int n4,n3,n2,n1;
#endif
/************************************************/
/* Dynamic 4D semi-contiguous memory allocator. */
/************************************************/
{
    unsigned char ****temp4;
    int i;
  
    if (!(temp4 = (unsigned char ****) malloc1((n4+1)*sizeof(***temp4))))
	return NULL;
    temp4[n4] = NULL;
    for (i=0; i<n4; i++)
	if (!(temp4[i] = malloc3(n3,n2,n1))) {
	    free4(temp4);
	    return (NULL);
	}
    return (temp4);
}

#ifdef ANSI_FUNC

void getsize2(
  unsigned char **buf,
  int *y_siz,
  int *x_siz
  )
#else

void getsize2(buf,y_siz,x_siz)
unsigned char **buf;
int *y_siz,*x_siz;
#endif
/*************************************************************
    Get size of 2d array allocated by malloc2() or malloc2c().
**************************************************************/
{
    for (*y_siz=0; buf[*y_siz]; (*y_siz)++);
    memcpy((char *) x_siz,(char *) (buf+*y_siz+1),sizeof(int));
}

#ifdef ANSI_FUNC

void getsize3(
  unsigned char ***buf,
  int *z_siz,
  int *y_siz,
  int *x_siz
  )
#else

void getsize3(buf,z_siz,y_siz,x_siz)
unsigned char ***buf;
int *z_siz,*y_siz,*x_siz;
#endif
/*************************************************************
    Get size of 3d array allocated by malloc3() or malloc3c().
**************************************************************/
{
    for (*z_siz=0; buf[*z_siz]; (*z_siz)++);
    for (*y_siz=0; buf[0][*y_siz]; (*y_siz)++);
    memcpy((char *) x_siz,(char *) (buf[0]+*y_siz+1),sizeof(int));
}

#ifdef ANSI_FUNC

void getsize4(
  unsigned char ****buf,
  int *z_siz,
  int *y_siz,
  int *x_siz,
  int *w_siz
  )
#else

void getsize4(buf,z_siz,y_siz,x_siz,w_siz)
unsigned char ****buf;
int *z_siz,*y_siz,*x_siz,*w_siz;
#endif
/*************************************************************
    Get size of 4d array allocated by malloc4() or malloc4c().
**************************************************************/
{
    for (*z_siz=0; buf[*z_siz]; (*z_siz)++);
    for (*y_siz=0; buf[0][*y_siz]; (*y_siz)++);
    for (*x_siz=0; buf[0][0][*x_siz]; (*x_siz)++);
    memcpy((char *) w_siz,(char *) (buf[0][0]+*x_siz+1),sizeof(int));
}

    Get size of 4d array allocated by malloc4() or malloc4c().
**************************************************************/
{
    for (*z_siz=0; buf[*z_siz]; (*z_siz)++);
    for (*y_siz=0; buf[0][*y_siz]; (*y_siz)++);
    for (*x_siz=0; buf[0][0][*x_siz]; (*x_siz)++);
    memcpy((char *) w_siz,(char *) (buf[0][0]+*x_siz+1),sizeof(int));
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久看| 97久久超碰国产精品电影| 欧美日韩mp4| 午夜精彩视频在线观看不卡| 欧美日韩国产综合视频在线观看| 亚洲精品福利视频网站| 欧美日韩午夜影院| 麻豆成人免费电影| 26uuu欧美| 99国产精品一区| 香蕉av福利精品导航| 日韩欧美一区二区免费| 国产精品一区二区在线看| 国产精品日日摸夜夜摸av| 色播五月激情综合网| 日韩精品一级中文字幕精品视频免费观看 | 777久久久精品| 免费成人深夜小野草| 国产日产欧美一区二区三区| 99re8在线精品视频免费播放| 亚洲图片一区二区| 欧美精品一区二区三区蜜桃视频| 国产传媒久久文化传媒| 一区二区三区日韩欧美| 日韩一区二区三免费高清| 粉嫩久久99精品久久久久久夜| 自拍偷在线精品自拍偷无码专区 | 日本精品视频一区二区| 日本va欧美va精品发布| 国产欧美精品国产国产专区| 欧美丝袜丝交足nylons| 国产揄拍国内精品对白| 亚洲一区二区中文在线| 亚洲精品在线三区| 在线看国产一区| 国产一区二区不卡| 亚洲成人在线网站| 亚洲国产精品黑人久久久| 欧美老年两性高潮| av在线不卡电影| 看电视剧不卡顿的网站| 亚洲精品成a人| 国产亚洲1区2区3区| 欧美三级中文字幕| 不卡av电影在线播放| 蜜桃视频第一区免费观看| 亚洲另类一区二区| 国产午夜亚洲精品羞羞网站| 欧美私人免费视频| 99re免费视频精品全部| 国产伦理精品不卡| 日韩精品成人一区二区在线| 亚洲天堂2016| 国产区在线观看成人精品| 欧美电影在线免费观看| 色综合久久久网| 国产999精品久久久久久| 久久精品久久精品| 视频一区二区中文字幕| 亚洲永久精品国产| 亚洲你懂的在线视频| 中文子幕无线码一区tr| 2021久久国产精品不只是精品| 欧美猛男gaygay网站| 色婷婷av一区二区三区之一色屋| 成人精品亚洲人成在线| 国产激情一区二区三区| 国产一区二区三区免费播放| 秋霞影院一区二区| 日本一区中文字幕| 蜜臀av性久久久久av蜜臀妖精| 天天综合网 天天综合色| 亚洲成人免费视频| 亚洲成a人v欧美综合天堂下载| 一区二区三区精品视频| 亚洲乱码国产乱码精品精小说| 亚洲视频图片小说| 一区二区三区免费网站| 一区二区三区影院| 亚洲图片一区二区| 五月综合激情婷婷六月色窝| 午夜亚洲福利老司机| 亚洲国产精品精华液网站| 五月天精品一区二区三区| 日韩国产欧美在线视频| 久久精品免费看| 国内不卡的二区三区中文字幕| 狠狠色狠狠色综合日日91app| 激情综合网激情| 国产suv精品一区二区883| 成人性生交大片免费看视频在线 | 懂色一区二区三区免费观看| 粉嫩aⅴ一区二区三区四区| av电影天堂一区二区在线| 91麻豆123| 欧美日韩免费一区二区三区 | 亚洲免费av在线| 亚洲国产视频一区| 日日夜夜一区二区| 精品一区二区在线视频| 成人午夜免费电影| 91福利国产精品| 欧美一区二区视频在线观看2020| 精品日韩一区二区三区| 国产精品免费免费| 亚洲成a人v欧美综合天堂 | 久久久久久久综合| 中文字幕中文字幕一区| 午夜精品爽啪视频| 国产裸体歌舞团一区二区| 色综合天天综合给合国产| 在线播放视频一区| 国产精品乱码一区二三区小蝌蚪| 亚洲欧美日韩在线不卡| 美女高潮久久久| 99久久国产免费看| 日韩限制级电影在线观看| 久久久久久久一区| 亚洲一区二区三区四区在线 | 国产成人精品一区二| 在线亚洲免费视频| 久久人人97超碰com| 亚洲精品视频在线| 国模冰冰炮一区二区| 欧美综合在线视频| 国产日产精品1区| 日韩av一区二| 色婷婷精品大在线视频| 久久婷婷国产综合精品青草| 亚洲国产乱码最新视频 | 成人国产亚洲欧美成人综合网| 欧美亚洲动漫另类| 中文字幕精品一区二区三区精品| 视频一区欧美精品| 99久久er热在这里只有精品66| 日韩精品在线网站| 亚洲综合视频在线| 成人永久aaa| 欧美成人三级电影在线| 亚洲一区二区三区三| 成人午夜视频在线| 精品理论电影在线观看| 午夜一区二区三区视频| 色婷婷综合激情| 久久久av毛片精品| 麻豆极品一区二区三区| 欧美日韩国产成人在线91| 亚洲欧美日韩在线不卡| 成人av资源网站| 亚洲精品一区二区三区精华液 | 麻豆精品国产传媒mv男同 | 五月婷婷综合激情| 在线观看国产精品网站| ...av二区三区久久精品| 国产成人亚洲精品青草天美| 日韩午夜激情免费电影| 日本欧洲一区二区| 欧美日韩高清一区二区三区| 亚洲日本韩国一区| 99精品视频免费在线观看| 亚洲国产精品精华液2区45| 国产成都精品91一区二区三| 欧美成人精品福利| 六月丁香综合在线视频| 欧美一区二区三区四区久久| 日韩精品一级中文字幕精品视频免费观看 | 国产精品初高中害羞小美女文| 欧美不卡一区二区三区四区| 午夜精品福利一区二区三区av| 欧美色电影在线| 亚洲成av人**亚洲成av**| 欧美三级视频在线| 亚洲一级二级在线| 欧美绝品在线观看成人午夜影视| 亚洲一区二区美女| 欧美日本免费一区二区三区| 午夜精品123| 日韩一区二区三区免费看 | 精品日韩成人av| 国产一区二区三区免费看 | 国产精品久久久久9999吃药| 成人高清视频免费观看| 亚洲日本欧美天堂| 在线观看av一区二区| 天堂一区二区在线| 日韩免费在线观看| 国产一区二区视频在线播放| 中文字幕免费观看一区| av一区二区三区四区| 亚洲一区二区综合| 欧美r级在线观看| 东方欧美亚洲色图在线| 亚洲另类在线视频| 日韩午夜在线影院| 成人福利视频在线看| 亚洲一区二区三区中文字幕在线 | 91免费视频网址| 亚洲123区在线观看| 日韩欧美久久久| 不卡区在线中文字幕|