⑴ 急高手相助!求数据结构算法设计(C语言)通讯录算法一个!
http://download.pudn.com/downloads82/ebook/107215774TheCProgramLanguage.rar
通讯录管理系统,具有数据插入、修改、显示、查询功能的电话簿管理程序
这还有很多,http://www.pudn.com/search_db.asp?keyword=%CD%A8%D1%B6%C2%BC+C%D3%EF%D1%D4&p=
那个不行的话发地址我给你下载。
⑵ 通讯录拼音搜索模糊匹配的算法问题
我用java写了个简单的,你可以多测试下:
publicstaticvoidmain(String[]args){
String[]name={"wang","hai","bao"};
String[]tests={"whb","WaHB","wangHB","HB","wh","whbo","whba"};
for(Stringstring:tests){
System.out.println(string+":"+match(name,string));
}
}
publicstaticbooleanmatch(String[]source,Stringinput){
if(source==null||source.length==0||input==null||input.length()==0){
returnfalse;
}
Stringtemp;
//统一转小写
input=input.toLowerCase();
for(inti=0;i<source.length;i++){
temp=source[i].toLowerCase();
if(temp==null||temp.length()==0){
returnfalse;
}
//最后一步特殊处理
if(i==source.length-1){
if(temp.startsWith(input)){
returntrue;
}
}
//输入的字符完全匹配到
if(input.startsWith(temp)){
//匹配到后生成新的字符串
input=input.substring(0,input.indexOf(temp));
//System.out.println("temp:"+temp+" 匹配到后input:"+input);
}
//首字母匹配到
elseif(temp.startsWith(input.substring(0,1))){
input=input.substring(1);
//System.out.println("temp:"+temp+" 匹配到后input:"+input);
}else{
returnfalse;
}
//表示匹配结束
if(input.length()==0){
returntrue;
}
}
returnfalse;
}
⑶ 设计课题八:简单的同学通讯录程序设计
#include <cstdio>
#include <cstdlib>
#include <cstring>
int count=1;
struct node
{
char num[20];
char name[20];
char sex[20];
char work[50];
char phone[20];
char email[20];
};
node *stu;
int cmp(char *a,char *b)
{
int a1=strlen(a),b1=strlen(b),i;
if(a1>b1)
{
return 0;
}
else if(a1<b1)
{
return 1;
}
else
{
for(i=0;i<a1;i++)
{
if(a[i]>b[i])
{
return 0;
}
else if(a[i]<b[i])
{
return 1;
}
}
}
}
int start()
{
int n;
printf(" *********************WELCOME********************\n");
printf(" ******* (1).添加数据 *******\n");
printf(" ******* (2).删除数据 *******\n");
printf(" ******* (3).修改数据 *******\n");
printf(" ******* (4).统计(男,女人数,总人数) *******\n");
printf(" ******* (5).查询数据 *******\n");
printf(" ******* (6).打开文件 *******\n");
printf(" ******* (7).文件排序 *******\n");
printf(" ******* (8).退出程序 *******\n");
printf(" ************************************************\n");
printf("请输入您的选择:\n");
scanf("%d",&n);
return n;
}
int main()
{
int count1=0,count2=0;
int n,i,j,flag,o;
int k;
FILE *fp;
node r;
char file[20];
char nnum[20];
char nname[20];
char nsex[20];
char nwork[50];
char nphone[20];
char nemail[20];
while(1)
{
n = start();
switch(n)
{
case 1:
printf("(1).添加数据\n");
printf("请输入添加的人的学号,姓名,性别,工作单位,电话号码,E-mail地址:\n");
scanf("%s%s%s%s%s%s",nnum,nname,nsex,nwork,nphone,nemail);
printf("请输入存储的的文件名:\n");
scanf("%s",file);
printf("文件是否存在?(1,表存在 0,表不存在)\n");
scanf("%d",&k);
fp=fopen(file,"a+");
if(fp==NULL)
{
printf("文件创建失败,请重新操作!\n");
break;
}
else
{
if(k==0)
{
if(count==1)
fprintf(fp,"%15s %10s %10s %15s %15s %20s\n","学号","姓名","性别","工作单位","电话号码","E-mail地址");
count++;
}
fprintf(fp,"%15s %10s %10s %15s %15s %20s\n",nnum,nname,nsex,nwork,nphone,nemail);
}
fclose(fp);
system("cls");
break;
case 2:
printf("(2).删除数据\n");
printf("请输入文件名:\n");
scanf("%s",file);
printf("请输入删除人物的名字:\n");
scanf("%s",nname);
fp=fopen(file,"a+");
if(fp==NULL)
{
printf("文件读取失败,请重新操作!\n");
break;
}
else
{
stu=NULL;
for(i=0;!feof(fp);i++) //读取文件
{
if(i==0)
stu=(node *)malloc(sizeof(node));
else
stu=(node *)realloc(stu,sizeof(node)*(i+1));
fscanf(fp,"%s %s %s %s %s %s",stu[i].num,stu[i].name,stu[i].sex,stu[i].work,stu[i].phone,stu[i].email);
}
fclose(fp);
flag=0;
fp=fopen(file,"w+");
for(j=0;j<i-1;j++)
{
if(strcmp(stu[j].name,nname)!=0)
{
fprintf(fp,"%15s %10s %10s %15s %15s %20s\n",stu[j].num,stu[j].name,stu[j].sex,stu[j].work,stu[j].phone,stu[j].email);
}
else
{
flag=1;
}
}
fclose(fp);
system("cls");
if(flag==0)
{
printf("文件名:%s\n",file);
printf("无此人!请重新操作!\n");break;
}
}
break;
case 3:
printf("(3).修改数据\n");
printf("请输入文件名:\n");
scanf("%s",file);
printf("请输入修改人物的信息:\n");
scanf("%s%s%s%s%s%s",nnum,nname,nsex,nwork,nphone,nemail);
fp=fopen(file,"a+");
stu=NULL;
for(i=0;!feof(fp);i++) //读取文件
{
if(i==0)
stu=(node *)malloc(sizeof(node));
else
stu=(node *)realloc(stu,sizeof(node)*(i+1));
fscanf(fp,"%s %s %s %s %s %s",stu[i].num,stu[i].name,stu[i].sex,stu[i].work,stu[i].phone,stu[i].email);
}
fclose(fp);
flag=0;
fp=fopen(file,"w+");
for(j=0;j<i-1;j++)
{
if(strcmp(stu[j].name,nname)!=0)
{
fprintf(fp,"%15s %10s %10s %15s %15s %20s\n",stu[j].num,stu[j].name,stu[j].sex,stu[j].work,stu[j].phone,stu[j].email);
}
else
{
fprintf(fp,"%15s %10s %10s %15s %15s %20s\n",nnum,nname,nsex,nwork,nphone,nemail);
flag=1;
}
}
fclose(fp);
system("cls");
if(flag==0)
{
printf("文件名:%s\n",file);
printf("无此人!请重新操作!\n");break;
}
break;
case 4:
printf("(4).统计(男,女人数,总人数)\n");
printf("请输入文件名:\n");
scanf("%s",file);
fp=fopen(file,"a+");
stu=NULL;
for(i=0;!feof(fp);i++) //读取文件
{
if(i==0)
stu=(node *)malloc(sizeof(node));
else
stu=(node *)realloc(stu,sizeof(node)*(i+1));
fscanf(fp,"%s %s %s %s %s %s",stu[i].num,stu[i].name,stu[i].sex,stu[i].work,stu[i].phone,stu[i].email);
}
fclose(fp);
system("cls");
count1=0,count2=0;
for(j=0;j<i-1;j++)
{
if(strcmp(stu[j].sex,"男")==0)
{
count1++;
}
else if(strcmp(stu[j].sex,"女")==0)
{
count2++;
}
}
printf("文件名:%s\n",file);
printf("男生数:%d\n",count1);
printf("女生数:%d\n",count2);
printf("总人数:%d\n",count1+count2);
break;
case 5:
printf("(5).查询数据\n");
printf("请输入文件名:\n");
scanf("%s",file);
printf("请输入查询人的名字:\n");
scanf("%s",nname);
fp=fopen(file,"a+");
stu=NULL;
for(i=0;!feof(fp);i++) //读取文件
{
if(i==0)
stu=(node *)malloc(sizeof(node));
else
stu=(node *)realloc(stu,sizeof(node)*(i+1));
fscanf(fp,"%s %s %s %s %s %s",stu[i].num,stu[i].name,stu[i].sex,stu[i].work,stu[i].phone,stu[i].email);
}
fclose(fp);
system("cls");
flag=0;
for(j=0;j<i-1;j++)
{
if(strcmp(stu[j].name,nname)==0)
{
printf("文件名:%s\n",file);
printf("%s %s %s %s %s %s\n",stu[j].num,stu[j].name,stu[j].sex,stu[j].work,stu[j].phone,stu[j].email);
flag=1;
break;
}
}
if(flag==0)
{
printf("文件名:%s\n",file);
printf("无此人!请重新操作!\n");break;
}
break;
⑷ C++简单通讯录的设计与实现
去网络文库找经典C程序吧,然后自己改改!
⑸ 抖音的算法思维是什么
1、抖音推荐算法第一要看发作品受欢迎的程度,简单说就是:点赞数评论数转发数完播率,也就 是说,新视频的完播率高,互动率高,这个视频才有机会持续加持流量;第二看 抖音账号权重大小,抖音账户权重基本算法=在抖音爸爸这里的位置。抖音推荐上热门的基础逻辑:基础流量、推荐叠加、时间效应。
2、抖音搜索算法搜索流量的秘密,用户搜索——浏览视频——涨粉变现, 而且抖音搜索算法还有以下三个特点:精准、持续性强、被动享受。 通过关键词字面意思,我们就可以知道,用户搜 索这个关键词的目的是什么。如果你是与关键词相关的内容,那搜索这个关键词的用户对你来说就是非常精准的潜在客户。如果你的视频标题和视频内容吸引了他的注意,点击你的视频,并且被你的视频所吸引, 进而就会进入你的账号主页,然后找到你的联系方式,最后成交。因此你要知道如何去布局抖音关键词,你布局的 关键词越多,精准性越高,关键词排名越好,你的流量也就越大。
⑹ C语言程序设计:通讯录程序设计
#include "stdlib.h"
#include "string.h"
#include "conio.h"
#include "stdio.h"
#include "dos.h"
FILE *fp;
int i; //i是全局变量 可代替length
struct address
{ char postnum[10];
char a[40]; //家庭地址
};
struct birthday
{ int year;
int month;
int day;
};
struct ffriend
{ int num; //序号
char name[20];
char sex;
char telephone[13];
struct birthday birthday;
struct address address;
}
friends[50];
void Load()
{
int j;
long k;
fp=fopen("friend.txt","a+"); //打开文件friend.txt
if(fp!=NULL)
{
for(i=1;i<50;i++)
{
j=fgetc(fp);
if(j==EOF) //判断是否到了文件尾
return;
k=i-1;
fseek(fp,k*sizeof(struct ffriend),SEEK_SET);
fread(&friends[i],sizeof(struct ffriend),1,fp); //从文件中读取一条记录
}
}
else
{
fp=fopen("friend.txt","w");
i=1;
}
}
void Show(int j)
{
// friends[j].num=i;
printf("\n\n\t编号-Nnumber: %3d",friends[j].num);
printf("\n\t姓名-Name:%-20s",friends[j].name);
printf("\n\t性别-Sex:%c",friends[j].sex);
printf("\n\t联系电话-Telephone:%-13s",friends[j].telephone);
printf("\n\t出生日期-Birthday:%4d-%2d-%3d",friends[j].birthday.year,friends[j].birthday.month,friends[j].birthday.day);
printf("\n\t邮编-Postnum:%-10s",friends[j].address.postnum);
printf("\n\t通信地址-address:%-40s",friends[j].address.a);
}
void Append(int j)
{
fflush(stdin); //区内清除文件缓冲区,文件以写方式打开时将缓冲容写入文件
//stdin是一个标准FILE*(文件型指针)指向通常是用键盘的输入的输入流
friends[j].num=j;
printf("\n\t\t\t序号-Number:%d",j);
printf("\n\t\t\t姓名-Name:");
scanf("%s",friends[j].name);
fflush(stdin); //为什么没有fflush(stdin); 的效果会自动跳过呢?
printf("\t\t\t性别-Sex(m/w):"); //为什么输入汉字男女也会自动跳过联系电话呢
scanf("%c",&friends[j].sex);
printf("\t\t\t联系电话-telephone:");
scanf("%s",friends[j].telephone);
printf("\t出生日期-birthday");
printf("\n\t\t\t年份-year:");
scanf("%d",&friends[j].birthday.year);
printf("\t\t\t月份-month:");
scanf("%d",&friends[j].birthday.month);
printf("\t\t\t日-day:");
scanf("%d",&friends[j].birthday.day);
printf("\t\t\t邮编-Postnumber:");
scanf("%s",friends[j].address.postnum);
printf("\t\t\t通信地址-Address:");
scanf("%s",friends[j].address.a);
getchar();
}
void Delete()
{
int k;
printf("\n\tDelete 序号-Number:");
scanf("%d",&k);
if(k<=i)
{
for(int j=k;j<i+1;j++) /*插入位置后的元素顺序后移*/
{
strcpy(friends[j].name,friends[j+1].name); /*交换元素内容*/
friends[j].sex=friends[j+1].sex;
strcpy(friends[j].telephone,friends[j+1].telephone);
friends[j].birthday.year=friends[j+1].birthday.year;
friends[j].birthday.month=friends[j+1].birthday.month;
friends[j].birthday.day=friends[j+1].birthday.day;
strcpy(friends[j].address.postnum,friends[j+1].address.postnum);
strcpy(friends[j].address.a,friends[j+1].address.a);
}
i--;
}
else
{
printf("输入的序号太大!");
}
}
void Modify(int j)
{
Append(j);
}
void Save()
{
int j;
fp=fopen("friend.txt","w");
for(j=1;j<=i;j++)
{
fwrite(&friends[j],sizeof(struct ffriend),1,fp);
}
fclose(fp);
}
void main()
{
int j;
char grade;
char searchname[10];
Load();
i--;
do
{
printf("\t\t\t\t简易通讯录\n\n");
printf("功能选择(Function choose)\n");
printf("\1A.读取(Read)\n");
printf("\2B.增添(Append)\n");
printf("\6C.插入(Insert)\n");
printf("\5D.删除(Delete)\n");
printf("\5E.查询(Search)\n");
printf("\6F.修改(Modify)\n");
printf("\2G.保存(Save)\n");
printf("\1H.退出(Quit)\n");
printf("请选择(Choice)\n注:输入A~H的大写字母\n");
scanf("%c",&grade);
switch(grade)
//加个大写和小写 都可以啊
{
case 'A': j=1; //显示功能
while(getchar()!=0x1b&&j<=i) //增添按Esc键退出
{
Show(j++);
printf("\n请按回车键继续!");
}
if(j-1<1)
{
printf("\n\t空文档,无任何记录-Empty Note\n");
printf("\n请按回车键继续!");
getchar();
}
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'B': //增加功能
while(i<=50) //增加按ESC键退出的功能
{
i++;
Append(i);
printf("\t是否继续增加?y/n");
//修改 加上else if 其他就跳出或强制打印出出错
char a=getchar();
if(a=='n'||a=='N')
break;
}
if(i==51)
printf("\n\t文档已满,无法增加记录-note full");
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
getchar();
break;
case 'C':
int k;
printf("\n\t输入要插入的位置:");
scanf("%d",&k);
j=i+1;
friends[j].num=j;
for(j;j>k;j--) //插入功能
{
strcpy(friends[j].name,friends[j-1].name); //数据后移
friends[j].sex=friends[j-1].sex;
strcpy(friends[j].telephone,friends[j-1].telephone);
friends[j].birthday.year=friends[j-1].birthday.year;
friends[j].birthday.month=friends[j-1].birthday.month;
friends[j].birthday.day=friends[j-1].birthday.day;
strcpy(friends[j].address.postnum,friends[j-1].address.postnum);
strcpy(friends[j].address.a,friends[j-1].address.a);
}
Append(k);
i++;
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'D': //删除功能 //增添随意删除多条记录的功能
Delete();
if(i<1)
printf("\n没有记录-No records\n");
printf("\n请按回车键继续!");
getchar();
getchar();
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'E': //查询功能
printf("\n\t请输入要查询记录的相关姓名:"); //增添查询按列号的
scanf("%s",searchname);
for(j=1;j<=i;j++)
{
if(strcmp(searchname,friends[j].name)==0) //比较字符串
{
Show(j);
break;
}
}
if(i<1)
{
printf("\n 没有您所查询的记录-No records");
printf("\n 请按回车键继续!");
getchar();
}
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
getchar();
break;
case 'F': //修改功能 / /增添按序列号查询
printf("\n\t请输入要修改记录的相关姓名:");
gets(searchname);
scanf("%s",searchname);
for(j=1;j<=i;j++)
{
if(strcmp(searchname,friends[j].name)==0) //比较字符串
{
Modify(j);
// getchar(); //加个输出确定修改吗
}
}
if(i<1) //修改功能
{ printf("\n 没有您所要修改的记录-No records");
printf("\n 请按回车键继续!");
getchar();
getchar();
}
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'G':
Save(); //存盘功能
getchar();
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
break;
case 'H': //退出功能
char x;
printf("是否保存?yes/no\n");
scanf("%s",&x);
//getchar();
// getchar();
if(x=='y')
{
Save();
exit(0);
}
else
exit(0);
default:
printf("\n\t输入有误,请输入正确的序列号!");
printf("\n请按回车键继续!");
getchar();
printf("\n\t\t\t\t\t\t\t此次操作结束");
printf("\n\t------------------------------------------------------------\t\t\n");
}
}while(1);
}
⑺ 通讯录管理系统
我这里有一个,你看看吧,满意的给分哦(在visual c++6.0上运行)
#include<stdlib.h>
#include<string.h> /*使用字符串函数*/
#include<conio.h> /*使用通过控制台进行数据输入和数据输出的函数*/
#include<stdio.h>
#include<dos.h> /*使用DOS函数*/
int i; /*定义一个全局变量i*/
struct addr /*定义通讯地址结构体*/
{ char post_num[10]; /*邮编*/
char addr[60]; /*家庭地址*/
};
struct birth /*定义出生年月结构体*/
{ int year; /*年份*/
int month; /*月份*/
int day; /*日期*/
};
struct record1 /*定义电子通讯录结构体*/
{ int number; /*序号*/
char name[20]; /*姓名*/
char sex; /*性别*/
struct birth birth; /*出生年月*/
struct addr addr; /*通信地址*/
char telephone[13]; /*联系电话*/
}records[50];
FILE *fp; /*定义指向file类型结构体的指针变量*/
void Data_Load() /*定义载入数据函数*/
{ int j;
long k;
fp=fopen("record.txt","r+t"); /*打开文件record.txt,进行读写*/
if(fp!=NULL) /*如果文件不为空*/
{ for(i=1;i<50;i++)
{ j=fgetc(fp); /*从"records.txt"文件读入整型数字*/
if(j==EOF) /*判断是否到了文件尾*/
return; /*如果到了结尾,返回*/
k=i-1;
fseek(fp,k*sizeof(struct record1),SEEK_SET); /*将位置指针移到record1结构体所含字节
的第k倍个字节处*/
fread(&records[i],sizeof(struct record1),1,fp); /*读取一条记录*/
}
}
else
{ fp=fopen("record.txt","w"); /*打开文件record.txt,只写*/
i=1;
}
}
void Data_Show(int j) /*定义显示数据函数*/
{
printf("\n\n\tNo:%3d\n",records[j].number); /*序号*/
printf("\n\tname:%2s\n",records[j].name); /*姓名*/
printf("\n\tbirthday (y/m/d):%4d%2d%2d", records[j].birth.year, records[j].birth.month,
records[j].birth.day); /*打印第j个成员的出生年月日*/
printf("\n\tpost code:%-10s",records[j].addr.post_num); /*邮编*/
printf("\n\taddress:%-40s",records[j].addr.addr); /*家庭地址*/
printf("\n\tphone%-13s",records[j].telephone); /*联系电话*/
}
void Data_Input(int j) /*定义添加数据函数*/
{
fflush(stdin); /*清空输入缓冲区*/
records[j].number=j;
printf("\n\n\n\tinputNo %d ",j);
printf("\n\tname:"); /*输入姓名*/
scanf("%s",records[j].name);
fflush(stdin); /*清空输入缓冲区*/
printf("\tsex(m/f):"); /*输入性别*/
scanf("%c",&records[j].sex);
printf("\t---birthday---"); /*输入出生年月*/
printf("\n\tyear:");
scanf("%d",&records[j].birth.year);
printf("\tmonth:");
scanf("%d",&records[j].birth.month);
printf("\tday:");
scanf("%d",&records[j].birth.day);
printf("\tpost code:"); /*输入邮编*/
scanf("%s",records[j].addr.post_num);
printf("\taddress:"); /*输入家庭地址*/
scanf("%s",records[j].addr.addr);
printf("\tphone:"); /*输入联系电话*/
scanf("%s",records[j].telephone);
}
void Data_Save() /*定义保存函数*/
{
int j;
fp=fopen("record.txt","w"); /*打开文件record.txt,只写*/
for(j=1;j<=i;j++)
{ fwrite(&records[j],sizeof(struct record1),1,fp); /*将结构体变量records的确定个数字节输
入到record.txt文件中,个数为结构体friend1所含字节数*/
}
}
void main() /*主函数*/
{
int j,k;
char ch;
char search_name[40]; /*定义字符串变量*/
Data_Load(); /*声明载入数据函数*/
i--;
do
{ printf("********************************* MENU ***************************************\n");
printf("------------------------! WELLCOME TO THE SYSTEM !------------------------------");
printf("\n*\tSelect Function: *");
printf("*\t1.Add New *");
printf("*\t2.View the data *");
printf("*\t3.Delete *");
printf("*\t4.Search *");
printf("*\t5.Insert *");
printf("*\t6.Save and quit *");
printf("*\t7.Quit *");
printf("\n******************************** MENU ****************************************\n");
printf("\tPlease choose the option you need:");
ch=getche(); /*输入字符*/
switch(ch)
{
case '1':
{ int p;
printf("\n\tPlease input the number of people you want to add:");
scanf("%d",&p);/*增加记录*/
printf("\tPlease press ENTER again");
while(getch()!=0x1b&&i<p)
{ i++;
Data_Input(i);
printf("Please press Enter again to continue\n");
}
if(i==p)printf("\n\tThe data is full\n");
} /*记录完后显示通讯录已满*/
break;
case '2': j=1; /*打印所有记录*/
while(getch()!=0x1b&&j<=i) Data_Show(j++); /*声明打印数据函数*/
if(j>i) printf("\n\tThe system is end\n"); /*显示记录末尾*/
break;
case '3': /*删除通讯录中的记录*/
if(i<1)
{ printf("\n\tno record\n"); /*显示无记录*/
break;
}
printf("\n\tplease input the number you want to delect:");
scanf("%d",&k);
printf("\tsucceed!\n");
for(j=k;j<i;j++) /*将删除位置后的元素顺序前移,即后一数据复制到前一位置,循环操作*/
{ strcpy(records[j].name,records[j+1].name);
records[j].sex=records[j+1].sex;
records[j].birth.year=records[j+1].birth.year;
records[j].birth.month=records[j+1].birth.month;
records[j].birth.day=records[j+1].birth.day;
strcpy(records[j].addr.post_num,records[j+1].addr.post_num);
strcpy(records[j].addr.addr,records[j+1].addr.addr);
strcpy(records[j].telephone,records[j+1].telephone);
}
i--; /*元素总数减1*/
break;
case '4': /*通讯录搜索功能*/
printf("\n\tPlease input the name:"); /*输入名字*/
scanf("%s", search_name); /*获得名字到指针型字符串变量*/
for(j=1;j<=i;j++)
{
if(strcmp(search_name,records[j].name)==0) /*比较字符串,即查看是否与记录中名字
相同*/
{ Data_Show(j);
printf("\n"); /*搜索成功,打印记录结束循环*/
break;
}
}
if(j>i) /*搜索失败*/
printf("\n\tNo Record "); /*显示无此记录*/
break;
case '5':
printf("\n\tInsert No:"); /*录入插入位置*/
scanf("%d",&k);
for(j=k+1;j<i;j++) /*将插入位置后的元素顺序后移,即将其复制到后一位置,循环操作*/
{ strcpy(records[j].name,records[j-1].name);
records[j].sex=records[j-1].sex;
records[j].birth.year=records[j-1].birth.year;
records[j].birth.month=records[j-1].birth.month;
records[j].birth.day=records[j-1].birth.day;
strcpy(records[j].addr.post_num,records[j-1].addr.post_num);
strcpy(records[j].addr.addr,records[j-1].addr.addr);
strcpy(records[j].telephone,records[j-1].telephone);
}
Data_Input(k); /*声明增加数据函数*/
i++;/*将记录数目加一*/
break;
case '6': Data_Save();
printf("\n"); /*声明保存函数*/
exit(0); break; /*保存后退出*/
case '7': printf("\n\tsave or not?:(y/n)");
ch=getch(); /*获得输入字符*/
if(ch=='y') Data_Save();
fclose(fp); /*关闭record.txt文件*/
exit(0); /*退出程序*/
default: printf("Please choose1-4\n"); /*输入的如果不是数字1-4,让其重新输入*/
}
}
while(1); /*每次都从第一个功能开始,循环操作*/
}
请采纳答案,支持我一下。
⑻ 要求:为某个单位建立一个员工通讯录管理系统,可以方便地查询每一个员工的办公室电话号码、手机号码及电
(1)∵由题意知甲获得实习机会需要笔试和面试得分之和至少为25分,包括两种情况:一是笔试和面试得分之和为25分;二是笔试和面试得分之和为30分,这两种情况是互斥的笔试和面试得分之和为25分的概率为p1=C23×(34)2×14×C33×(12)3+C33×(34)3×C23×(12)2×12=27128,笔试和面试得分之和为30分的概率为p1=C33×(34)3×C33×(12)3=27512,∴甲获得实习机会的概率为p=p1+p2=27128+27512=135512.(2)ξ的取值为0,5,10,15,20,25,30.p(ξ=0)=C33×(14)3=164,p(ξ=5)=C13×34×(14)2=964,p(ξ=10)=C23×(34)2×14×C03×(12)3=27512,p(ξ=15)=C23×(34)2×14×C13×(12)3+C33×(34)3×C03×(12)3=108512,p(ξ=20)=C23×(34)2×14×C23×(12)3+C33×(34)3×C13×(12)3=162512,由(1)知p(ξ=25)=108512,p(ξ=30)=27512.∴Eξ=0×164+5×964+10×27512+15×108512+20×162512+25×108512+30×27512=112564
⑼ 20. 通讯录的制作 数据结构题目 用c或类c语言编写 并写出每句含义 谢啦!!!!
#include<stdio.h>#include<stdlib.h>#include<string.h>#define SIZE_NAME 10#define SIZE_ID 20#define SIZE_PHONE 20int Record = 0;
typedef struct {
char name[SIZE_NAME];
char id[SIZE_ID];
char phone[SIZE_PHONE];
}pInfo;
typedef struct node{
pInfo people;
struct node *next;
}linkList;int menu();int create(linkList *head);int display(linkList *head);int search(linkList *head, char *info);int modify(linkList *head, char *pid);int add2(linkList *head, char *pid);int delt(linkList *head, char *info);int compare(char *str1, char *str2);int sort_id(linkList *head, int boolean);//1升序 0降序
int sort_name(linkList *head, int boolean);//1升序 0降序int main()
{
linkList head, *p;
char info[SIZE_ID]; int temp, chus, i;
head.next = NULL; while (1) {
switch (menu()) {
case 1:
create(&head); break;
case 2:
display(&head); break;
case 3: printf("请输入需要查询的学号或姓名: ");
scanf("%s", info);
p = &head;
p = p->next; for (i = 0; i < search(&head, info); i++) {
p = p->next;
} printf("搜索到:
"); printf(" 联系人
"); printf("--------------------------------------------------------------------------------
"); printf(" 学号 姓名 电话
"); printf("--------------------------------------------------------------------------------
"); printf("%20s ", p->people.id); printf("%10s ", p->people.name); printf("%20s
", p->people.phone);
search(&head, info); break;
case 4: printf("请输入需要修改的学号: ");
scanf("%s", info);
modify(&head, info); break;
case 5: printf("请输入需要添加的学号: ");
scanf("%s", info);
add2(&head, info); break;
case 6: printf("请输入需要删除的学号或姓名: ");
scanf("%s", info);
delt(&head, info); break;
case 7: printf("请选择排序方式:
1.按学号排序
2.按姓名排序
");
scanf("%d", &chus);
switch (chus) {
case 1: printf("请输入1或0:
1:升序
0:降序
");
scanf("%d", &temp);
sort_id(&head, temp); break;
case 2: printf("请输入1或0:
1:升序
0:降序
");
scanf("%d", &temp);
sort_name(&head, temp); break;
} break;
case 8: exit(0); break;
default: printf("输错了,再来一次
");
} system("pause"); system("cls");
} system("pause"); return 0;
}int menu()
{ int chus; printf(" 通讯录
"); printf("请输入(1 -- 8):
"); printf(" 1.创建通讯录
"); printf(" 2.显示通讯录
"); printf(" 3.查询通讯录
"); printf(" 4.修改通讯录
"); printf(" 5.添加通讯录
"); printf(" 6.删除通讯录
"); printf(" 7.排序通讯录
"); printf(" 8.退出
");
scanf("%d", &chus); return chus;
}int create(linkList *head)
{
linkList *s, *p;
p = head; printf("请输入学号 姓名 电话,输入end结束
"); while (1) { s = (linkList*)malloc(sizeof(linkList));
scanf("%s", s->people.id); if (!strcmp(s->people.id,"end")){ return 0;
}
scanf("%s", s->people.name);
scanf("%s", s->people.phone); s->next = p->next;
p->next = s;
p = s;
Record++;
} return 0;
}int display(linkList *head)
{ int i;
linkList *p;
p = head;
p = p->next; printf(" 联系人
"); printf("--------------------------------------------------------------------------------
"); printf(" 学号 姓名 电话
"); printf("--------------------------------------------------------------------------------
"); for (i = 0; i < Record; i++, p = p->next) { printf("%20s ", p->people.id); printf("%10s ", p->people.name); printf("%20s
", p->people.phone);
} return 0;
}int search(linkList *head, char *info)
{ int i;
linkList *p;
p = head;
p = p->next; for (i = 0; i < Record; i++, p = p->next) { if ((!strcmp(p->people.id, info)) || (!strcmp(info,p->people.name))){ return i;
}
} return -1;
}int modify(linkList *head, char *pid)
{ int i;
linkList *p;
p = head;
p = p->next; for (i = 0; i < search(head, pid); i++) {
p = p->next;
} printf("请输入新信息:
");
scanf("%s", p->people.id);
scanf("%s", p->people.name);
scanf("%s", p->people.phone); return 0;
}int add2(linkList *head, char *pid)
{ int i;
linkList *p, *s;
p = head;
p = p->next; s = (linkList*)malloc(sizeof(linkList)); while( p->next!= NULL){
p = p->next;
} printf("请输入需要添加的姓名和电话:
");
strcpy(s->people.id, pid);
scanf("%s", s->people.name);
scanf("%s", s->people.phone); if (search(head, s->people.id) == -1) { s->next = p->next;
p->next = s;
Record++;
} else { printf("学号重复了
");
} return 0;
}int delt(linkList *head, char *info)
{ int i, n;
linkList *p, *s;
p = head;
n = search(head, info); if (-1 == n) { printf("没有找到
"); return 0;
} for (i = 0; i < n; i++) {
p = p->next;
}
p->next = p->next->next;
Record--; return 0;
}int compare(char *str1, char *str2)
{ int i; for (i = 0; i < strlen(str1); i++) { if (str1[i] < str2[i]) { return 1;
}
} return 0;
}int sort_id(linkList *head, int boolean)
{
linkList *p, *pre;
pInfo temp; if (boolean) { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (0 == compare(p->people.id, pre->people.id)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} else { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (1 == compare(p->people.id, pre->people.id)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} return 0;
}int sort_name(linkList *head, int boolean)
{
linkList *p, *pre;
pInfo temp; if (boolean) { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (0 == compare(p->people.name, pre->people.name)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} else { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (1 == compare(p->people.name, pre->people.name)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} return 0;
}#include<stdio.h>#include<stdlib.h>#include<string.h>#define SIZE_NAME 10#define SIZE_ID 20#define SIZE_PHONE 20int Record = 0;
typedef struct {
char name[SIZE_NAME];
char id[SIZE_ID];
char phone[SIZE_PHONE];
}pInfo;
typedef struct node{
pInfo people;
struct node *next;
}linkList;int menu();int create(linkList *head);int display(linkList *head);int search(linkList *head, char *info);int modify(linkList *head, char *pid);int add2(linkList *head, char *pid);int delt(linkList *head, char *info);int compare(char *str1, char *str2);int sort_id(linkList *head, int boolean);//1升序 0降序
int sort_name(linkList *head, int boolean);//1升序 0降序int main()
{
linkList head, *p;
char info[SIZE_ID]; int temp, chus, i;
head.next = NULL; while (1) {
switch (menu()) {
case 1:
create(&head); break;
case 2:
display(&head); break;
case 3: printf("请输入需要查询的学号或姓名: ");
scanf("%s", info);
p = &head;
p = p->next; for (i = 0; i < search(&head, info); i++) {
p = p->next;
} printf("搜索到:
"); printf(" 联系人
"); printf("--------------------------------------------------------------------------------
"); printf(" 学号 姓名 电话
"); printf("--------------------------------------------------------------------------------
"); printf("%20s ", p->people.id); printf("%10s ", p->people.name); printf("%20s
", p->people.phone);
search(&head, info); break;
case 4: printf("请输入需要修改的学号: ");
scanf("%s", info);
modify(&head, info); break;
case 5: printf("请输入需要添加的学号: ");
scanf("%s", info);
add2(&head, info); break;
case 6: printf("请输入需要删除的学号或姓名: ");
scanf("%s", info);
delt(&head, info); break;
case 7: printf("请选择排序方式:
1.按学号排序
2.按姓名排序
");
scanf("%d", &chus);
switch (chus) {
case 1: printf("请输入1或0:
1:升序
0:降序
");
scanf("%d", &temp);
sort_id(&head, temp); break;
case 2: printf("请输入1或0:
1:升序
0:降序
");
scanf("%d", &temp);
sort_name(&head, temp); break;
} break;
case 8: exit(0); break;
default: printf("输错了,再来一次
");
} system("pause"); system("cls");
} system("pause"); return 0;
}int menu()
{ int chus; printf(" 通讯录
"); printf("请输入(1 -- 8):
"); printf(" 1.创建通讯录
"); printf(" 2.显示通讯录
"); printf(" 3.查询通讯录
"); printf(" 4.修改通讯录
"); printf(" 5.添加通讯录
"); printf(" 6.删除通讯录
"); printf(" 7.排序通讯录
"); printf(" 8.退出
");
scanf("%d", &chus); return chus;
}int create(linkList *head)
{
linkList *s, *p;
p = head; printf("请输入学号 姓名 电话,输入end结束
"); while (1) { s = (linkList*)malloc(sizeof(linkList));
scanf("%s", s->people.id); if (!strcmp(s->people.id,"end")){ return 0;
}
scanf("%s", s->people.name);
scanf("%s", s->people.phone); s->next = p->next;
p->next = s;
p = s;
Record++;
} return 0;
}int display(linkList *head)
{ int i;
linkList *p;
p = head;
p = p->next; printf(" 联系人
"); printf("--------------------------------------------------------------------------------
"); printf(" 学号 姓名 电话
"); printf("--------------------------------------------------------------------------------
"); for (i = 0; i < Record; i++, p = p->next) { printf("%20s ", p->people.id); printf("%10s ", p->people.name); printf("%20s
", p->people.phone);
} return 0;
}int search(linkList *head, char *info)
{ int i;
linkList *p;
p = head;
p = p->next; for (i = 0; i < Record; i++, p = p->next) { if ((!strcmp(p->people.id, info)) || (!strcmp(info,p->people.name))){ return i;
}
} return -1;
}int modify(linkList *head, char *pid)
{ int i;
linkList *p;
p = head;
p = p->next; for (i = 0; i < search(head, pid); i++) {
p = p->next;
} printf("请输入新信息:
");
scanf("%s", p->people.id);
scanf("%s", p->people.name);
scanf("%s", p->people.phone); return 0;
}int add2(linkList *head, char *pid)
{ int i;
linkList *p, *s;
p = head;
p = p->next; s = (linkList*)malloc(sizeof(linkList)); while( p->next!= NULL){
p = p->next;
} printf("请输入需要添加的姓名和电话:
");
strcpy(s->people.id, pid);
scanf("%s", s->people.name);
scanf("%s", s->people.phone); if (search(head, s->people.id) == -1) { s->next = p->next;
p->next = s;
Record++;
} else { printf("学号重复了
");
} return 0;
}int delt(linkList *head, char *info)
{ int i, n;
linkList *p, *s;
p = head;
n = search(head, info); if (-1 == n) { printf("没有找到
"); return 0;
} for (i = 0; i < n; i++) {
p = p->next;
}
p->next = p->next->next;
Record--; return 0;
}int compare(char *str1, char *str2)
{ int i; for (i = 0; i < strlen(str1); i++) { if (str1[i] < str2[i]) { return 1;
}
} return 0;
}int sort_id(linkList *head, int boolean)
{
linkList *p, *pre;
pInfo temp; if (boolean) { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (0 == compare(p->people.id, pre->people.id)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} else { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (1 == compare(p->people.id, pre->people.id)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} return 0;
}int sort_name(linkList *head, int boolean)
{
linkList *p, *pre;
pInfo temp; if (boolean) { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (0 == compare(p->people.name, pre->people.name)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} else { for (p = head->next; p != NULL; p = p->next) { for (pre = p->next; pre != NULL; pre = pre->next) { if (1 == compare(p->people.name, pre->people.name)) {
temp = p->people;
p->people = pre->people;
pre->people = temp;
}
}
}
} return 0;
}