C语言起步简单的一些经典题目4

memmove自定义实现

void* my_memmove(voiddest,const voidstr,size_t count)

{

assert(dest!=NULL);

assert(str!=NULL);

voidret=dest;if(dest-后while(count--){(char)dest=(char*)str;

++ *(char*)dest ; ++ *(char*)str ; } } else { //后>=前 while(count--) { *((char*)dest+count)=*((char*)str+count); } } return ret;

}

int main()

{

int arr[]={1,2,3,4,5,6,7,8,9,10};

//my_memcpy(arr+2,arr,20);

my_memmove(arr+2,arr,20);

int i=0;

for(i=0;i

{

printf("%d",arr[i]);

}

return 0;

}

memcmp实现

int main()

{

int arr1[]={1,2,3,4,5};

int arr2[]={1,2,5,4,3};

int ret=memcmp(arr1,arr2,9);

printf("%d",ret);

return 0;

}

通讯录实现

#define MAX 1000

#define MAX_NAME 20

#define MAX_SEX 5

#define TELE_MAX 12

#define ADDR_MAX 30

enum Option

{

EXIT,

ADD,

DEL,

SEARCH,

MODIFY,

SHOW,

SORT

};

void InitContact(struct Contactps);//增加一个信息到通讯录void AddContact(struct Contactps);

//打印通讯录的元素

void ShowContact(const struct Contactps);//删除指定的联系人void DelContact(struct Contactps);

//查找指定人的信息

void SearchContact(const struct Contactps);//修改指定联系人void ModifyContact(const struct Contactps);

//排序通讯录内容

void SortContact(struct Contactps);void menu(){printf("\n");printf("1.add 2.del\n");printf("3.search 4.modify\n");printf("5.show 6sort\n");printf("0.show\n");printf("***********\n");}struct PeoInfo{char name[ MAX_NAME];int age;char sex[MAX_SEX];char tele[TELE_MAX];char addr[ADDR_MAX];};struct Contact{struct PeoInfo data[MAX];//存放1000个信息int size;//记录当前已经有的元素个数};void InitContact(struct Contact ps)

{

ps->data;

memset(ps->data,0,sizeof(ps->data));

ps->size=0;

}

void AddContact(struct Contact* ps)

{

if(ps->size==MAX)

{

printf("通讯录已满,无法增加");

}

else

{

printf("请输入名字:>");

scanf("%s",ps->data[ps->size].name) ;

printf("请输入年龄:>");

scanf("%d",&(ps->data[ps->size].age)) ;

printf("请输入性别:>");

scanf("%s",ps->data[ps->size].sex) ;

printf("请输入电话:>");

scanf("%s",ps->data[ps->size].tele) ;

printf("请输入地址:>");

scanf("%s",ps->data[ps->size].addr) ;

ps->size++;

printf("添加成功");

}

}

void ShowContact(const struct Contactps){if(ps->size==0){printf("通讯录为空\n");}else{int i=0; printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n","名字","年龄","性别","电话","地址" );for(i=0;isize;i++){printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",ps->data[i].name,ps->data[i].age,ps->data[i].sex,ps->data[i].tele,ps->data[i].addr);}}}static int FindByName(const struct Contactps,char name[MAX_NAME])

{

int i=0;

for(i=0;isize;i++)

{

if(0==strcmp(ps->data[i].name,name));

{

return i;;

}

}

return -1;//找不到的情况

}

void DelContact( struct Contactps){char name[MAX_NAME];printf("请输入要删除人的名字:>");scanf("%s",name);//1.查找要删除的人在什么位置//找到返回名字所在元素的下标,找不到返回-1int pos=FindByName(ps,name);//2.删除if(pos==-1){printf("要删除的人不存在\n");}else{//删除数据int j=0;for(j=pos;jsize-1;j++){ps->data[j]=ps->data[j+1];}ps->size--;printf("删除成功\n");}}void SearchContact(const struct Contactps)

{

char name[MAX_NAME];

printf("请输入要查找人的名字\n");

scanf("%s",name);

int pos=FindByName(ps,name);

if(pos==-1)

{

printf("要查找的人不存在\n");

}

else

{

printf("%-20s\t%-4s\t%-5s\t%-12s\t%-20s\n","名字","年龄","性别","电话","地址" );

printf("%-20s\t%-4d\t%-5s\t%-12s\t%-20s\n",

ps->data[pos].name,

ps->data[pos].age,

ps->data[pos].sex,

ps->data[pos].tele,

ps->data[pos].addr);

}

}

void ModifyContact(const struct Contact*ps)

{

char name[MAX_NAME];

printf("请输入要修改人的名字:>");

scanf("%s",name);

int pos=FindByName(ps,name);

if(pos==-1)

{

printf("要修改的人信息不存在\n");

}

else

{

printf("请输入名字:>");

scanf("%s",ps->data[pos].name) ;

printf("请输入年龄:>");

scanf("%d",&(ps->data[pos].age)) ;

printf("请输入性别:>");

scanf("%s",ps->data[pos].sex) ;

printf("请输入电话:>");

scanf("%s",ps->data[pos].tele) ;

printf("请输入地址:>");

scanf("%s",ps->data[pos].addr) ;

printf("修改完成\n");

}

}

int main()

{

int input=0;

int size=0;

//创建通讯录

struct Contact con;

//初始化通讯录

InitContact(&con);

do

{

menu();

printf("请选择:>");

scanf("%d",&input);

switch(input)

{

case ADD:

AddContact(&con);

break;

case DEL:

DelContact(&con);

break;

case SEARCH:

SearchContact(&con);

break;

case MODIFY:

ModifyContact(&con);

break;

case SHOW:

ShowContact(&con);

break;

case SORT:

SortContact(&con);

break;

case EXIT:

printf("退出通讯录\n");

break;

default:

printf("选择错误\n");

break;

}

}while(input);

return 0;

}

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

アイシン

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值