老熟女激烈的高潮_日韩一级黄色录像_亚洲1区2区3区视频_精品少妇一区二区三区在线播放_国产欧美日产久久_午夜福利精品导航凹凸

重慶分公司,新征程啟航

為企業提供網站建設、域名注冊、服務器等服務

c語言通訊錄查重比較函數,c語言查重算法

用C語言做通訊錄

這看你是怎樣定義的了。如果你50個同學是用結構體來定義的話就比較容易實現。用二維數組的話,就比較麻煩。

創新互聯主要從事網頁設計、PC網站建設(電腦版網站建設)、wap網站建設(手機版網站建設)、響應式網站建設、程序開發、網站優化、微網站、微信小程序定制開發等,憑借多年來在互聯網的打拼,我們在互聯網網站建設行業積累了豐富的網站建設、成都網站建設、網站設計、網絡營銷經驗,集策劃、開發、設計、營銷、管理等多方位專業化運作于一體。

查找名字可以用strcmp(輸入的名字,編好的名字)==0如果相等,就等于查找到你輸入的名字了。記錄它的下標,再輸出它的聯系方式。

下面是一個比較完整的通訊錄代碼,你參考一下啦。(看到專家兩個字,我真沒資格去回答你了,汗)

/*10.3.2源程序*/

/******頭文件(.h)***********/

#include "stdio.h" /*I/O函數*/

#include "stdlib.h" /*標準庫函數*/

#include "string.h"/*字符串函數*/

#include "ctype.h" /*字符操作函數*/

#define M 50 /*定義常數表示記錄數*/

typedef struct /*定義數據結構*/

{

char name[20]; /*姓名*/

char units[30]; /*單位*/

char tele[10]; /*電話*/

}ADDRESS;

/******以下是函數原型*******/

int enter(ADDRESS t[]); /*輸入記錄*/

void list(ADDRESS t[],int n); /*顯示記錄*/

void search(ADDRESS t[],int n); /*按姓名查找顯示記錄*/

int delete(ADDRESS t[],int n); /*刪除記錄*/

int add(ADDRESS t[],int n); /*插入記錄*/

void save(ADDRESS t[],int n); /*記錄保存為文件*/

int load(ADDRESS t[]); /*從文件中讀記錄*/

void display(ADDRESS t[]); /*按序號查找顯示記錄*/

void sort(ADDRESS t[],int n); /*按姓名排序*/

void qseek(ADDRESS t[],int n); /*快速查找記錄*/

void copy(); /*文件復制*/

void print(ADDRESS temp); /*顯示單條記錄*/

int find(ADDRESS t[],int n,char *s) ; /*查找函數*/

int menu_select(); /*主菜單函數*/

/******主函數開始*******/

main()

{

int i;

ADDRESS adr[M]; /*定義結構體數組*/

int length; /*保存記錄長度*/

clrscr(); /*清屏*/

for(;;)/*無限循環*/

{

switch(menu_select()) /*調用主菜單函數,返回值整數作開關語句的條件*/

{

case 0:length=enter(adr);break;/*輸入記錄*/

case 1:list(adr,length);break; /*顯示全部記錄*/

case 2:search(adr,length);break; /*查找記錄*/

case 3:length=delete(adr,length);break; /*刪除記錄*/

case 4:length=add(adr,length); break; /*插入記錄*/

case 5:save(adr,length);break; /*保存文件*/

case 6:length=load(adr); break; /*讀文件*/

case 7:display(adr);break; /*按序號顯示記錄*/

case 8:sort(adr,length);break; /*按姓名排序*/

case 9:qseek(adr,length);break; /*快速查找記錄*/

case 10:copy();break; /*復制文件*/

case 11:exit(0); /*如返回值為11則程序結束*/

}

}

}

/*菜單函數,函數返回值為整數,代表所選的菜單項*/

menu_select()

{

char s[80];

int c;

gotoxy(1,25);/*將光標定為在第25行,第1列*/

printf("press any key enter menu......\n");/*提示壓任意鍵繼續*/

getch(); /*讀入任意字符*/

clrscr(); /*清屏*/

gotoxy(1,1);

printf("********************MENU*********************\n\n");

printf(" 0. Enter record\n");

printf(" 1. List the file\n");

printf(" 2. Search record on name\n");

printf(" 3. Delete a record\n");

printf(" 4. add record \n");

printf(" 5. Save the file\n");

printf(" 6. Load the file\n");

printf(" 7. display record on order\n");

printf(" 8. sort to make new file\n");

printf(" 9. Quick seek record\n");

printf(" 10. copy the file to new file\n");

printf(" 11. Quit\n");

printf("***********************************************\n");

do{

printf("\n Enter you choice(0~11):"); /*提示輸入選項*/

scanf("%s",s); /*輸入選擇項*/

c=atoi(s); /*將輸入的字符串轉化為整型數*/

}while(c11); /*選擇項不在0~11之間重輸*/

return c; /*返回選擇項,主程序根據該數調用相應的函數*/

}

/***輸入記錄,形參為結構體數組,函數值返回類型為整型表示記錄長度*/

int enter(ADDRESS t[])

{

int i,n;

char *s;

clrscr(); /*清屏*/

printf("\nplease input num \n"); /*提示信息*/

scanf("%d",n); /*輸入記錄數*/

printf("please input record \n"); /*提示輸入記錄*/

printf("name unit telephone\n");

printf("------------------------------------------------\n");

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

{

scanf("%s%s%s",t[i].name,t[i].units,t[i].tele); /*輸入記錄*/

printf("----------------------------------------------\n");

}

return n; /*返回記錄條數*/

}

/*顯示記錄,參數為記錄數組和記錄條數*/

void list(ADDRESS t[],int n)

{

int i;

clrscr();

printf("\n\n*******************ADDRESS******************\n");

printf("name unit telephone\n");

printf("------------------------------------------------\n");

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

printf("%-20s%-30s%-10s\n",t[i].name,t[i].units,t[i].tele);

if((i+1)%10==0) /*判斷輸出是否達到10條記錄*/

{

printf("Press any key continue...\n"); /*提示信息*/

getch(); /*壓任意鍵繼續*/

}

printf("************************end*******************\n");

}

/*查找記錄*/

void search(ADDRESS t[],int n)

{

char s[20]; /*保存待查找姓名字符串*/

int i; /*保存查找到結點的序號*/

clrscr(); /*清屏*/

printf("please search name\n");

scanf("%s",s); /*輸入待查找姓名*/

i=find(t,n,s); /*調用find函數,得到一個整數*/

if(in-1) /*如果整數i值大于n-1,說明沒找到*/

printf("not found\n");

else

print(t[i]); /*找到,調用顯示函數顯示記錄*/

}

/*顯示指定的一條記錄*/

void print(ADDRESS temp)

{

clrscr();

printf("\n\n********************************************\n");

printf("name unit telephone\n");

printf("------------------------------------------------\n");

printf("%-20s%-30s%-10s\n",temp.name,temp.units,temp.tele);

printf("**********************end***********************\n");

}

/*查找函數,參數為記錄數組和記錄條數以及姓名s */

int find(ADDRESS t[],int n,char *s)

{

int i;

for(i=0;in;i++)/*從第一條記錄開始,直到最后一條*/

{

if(strcmp(s,t[i].name)==0) /*記錄中的姓名和待比較的姓名是否相等*/

return i; /*相等,則返回該記錄的下標號,程序提前結結束*/

}

return i; /*返回i值*/

}

/*刪除函數,參數為記錄數組和記錄條數*/

int delete(ADDRESS t[],int n)

{

char s[20]; /*要刪除記錄的姓名*/

int ch=0;

int i,j;

printf("please deleted name\n"); /*提示信息*/

scanf("%s",s);/*輸入姓名*/

i=find(t,n,s); /*調用find函數*/

if(in-1) /*如果in-1超過了數組的長度*/

printf("no found not deleted\n"); /*顯示沒找到要刪除的記錄*/

else

{

print(t[i]); /*調用輸出函數顯示該條記錄信息*/

printf("Are you sure delete it(1/0)\n"); /*確認是否要刪除*/

scanf("%d",ch); /*輸入一個整數0或1*/

if(ch==1) /*如果確認刪除整數為1*/

{

for(j=i+1;jn;j++) /*刪除該記錄,實際后續記錄前移*/

{

strcpy(t[j-1].name,t[j].name); /*將后一條記錄的姓名拷貝到前一條*/

strcpy(t[j-1].units,t[j].units); /*將后一條記錄的單位拷貝到前一條*/

strcpy(t[j-1].tele,t[j].tele); /*將后一條記錄的電話拷貝到前一條*/

}

n--; /*記錄數減1*/

}

}

return n; /*返回記錄數*/

}

/*插入記錄函數,參數為結構體數組和記錄數*/

int add(ADDRESS t[],int n)/*插入函數,參數為結構體數組和記錄數*/

{

ADDRESS temp; /*新插入記錄信息*/

int i,j;

char s[20]; /*確定插入在哪個記錄之前*/

printf("please input record\n");

printf("************************************************\n");

printf("name unit telephone\n");

printf("--------------------------------------------------\n");

scanf("%s%s%s",temp.name,temp.units,temp.tele); /*輸入插入信息*/

printf("------------------------------------------------\n");

printf("please input locate name \n");

scanf("%s",s); /*輸入插入位置的姓名*/

i=find(t,n,s); /*調用find,確定插入位置*/

for(j=n-1;j=i;j--) /*從最后一個結點開始向后移動一條*/

{

strcpy(t[j+1].name,t[j].name); /*當前記錄的姓名拷貝到后一條*/

strcpy(t[j+1].units,t[j].units); /*當前記錄的單位拷貝到后一條*/

strcpy(t[j+1].tele,t[j].tele); /*當前記錄的電話拷貝到后一條*/

}

strcpy(t[i].name,temp.name); /*將新插入記錄的姓名拷貝到第i個位置*/

strcpy(t[i].units,temp.units); /*將新插入記錄的單位拷貝到第i個位置*/

strcpy(t[i].tele,temp.tele); /*將新插入記錄的電話拷貝到第i個位置*/

n++; /*記錄數加1*/

return n; /*返回記錄數*/

}

/*保存函數,參數為結構體數組和記錄數*/

void save(ADDRESS t[],int n)

{

int i;

FILE *fp; /*指向文件的指針*/

if((fp=fopen("record.txt","wb"))==NULL) /*打開文件,并判斷打開是否正常*/

{

printf("can not open file\n");/*沒打開*/

exit(1); /*退出*/

}

printf("\nSaving file\n"); /*輸出提示信息*/

fprintf(fp,"%d",n); /*將記錄數寫入文件*/

fprintf(fp,"\r\n"); /*將換行符號寫入文件*/

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

{

fprintf(fp,"%-20s%-30s%-10s",t[i].name,t[i].units,t[i].tele);/*格式寫入記錄*/

fprintf(fp,"\r\n"); /*將換行符號寫入文件*/

}

fclose(fp);/*關閉文件*/

printf("****save success***\n"); /*顯示保存成功*/

}

/*讀入函數,參數為結構體數組*/

int load(ADDRESS t[])

{

int i,n;

FILE *fp; /*指向文件的指針*/

if((fp=fopen("record.txt","rb"))==NULL)/*打開文件*/

{

printf("can not open file\n"); /*不能打開*/

exit(1); /*退出*/

}

fscanf(fp,"%d",n); /*讀入記錄數*/

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

fscanf(fp,"%20s%30s%10s",t[i].name,t[i].units,t[i].tele); /*按格式讀入記錄*/

fclose(fp); /*關閉文件*/

printf("You have success read data from file!!!\n"); /*顯示保存成功*/

return n; /*返回記錄數*/

}

/*按序號顯示記錄函數*/

void display(ADDRESS t[])

{

int id,n;

FILE *fp; /*指向文件的指針*/

if((fp=fopen("record.txt","rb"))==NULL) /*打開文件*/

{

printf("can not open file\n"); /*不能打開文件*/

exit(1); /*退出*/

}

printf("Enter order number...\n"); /*顯示信息*/

scanf("%d",id); /*輸入序號*/

fscanf(fp,"%d",n); /*從文件讀入記錄數*/

if(id=0idn) /*判斷序號是否在記錄范圍內*/

{

fseek(fp,(id-1)*sizeof(ADDRESS),1); /*移動文件指針到該記錄位置*/

print(t[id]); /*調用輸出函數顯示該記錄*/

printf("\r\n");

}

else

printf("no %d number record!!!\n ",id); /*如果序號不合理顯示信息*/

fclose(fp); /*關閉文件*/

}

/*排序函數,參數為結構體數組和記錄數*/

void sort(ADDRESS t[],int n)

{

int i,j,flag;

ADDRESS temp; /*臨時變量做交換數據用*/

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

{

flag=0; /*設標志判斷是否發生過交換*/

for(j=0;jn-1;j++)

if((strcmp(t[j].name,t[j+1].name))0) /*比較大小*/

{

flag=1;

strcpy(temp.name,t[j].name); /*交換記錄*/

strcpy(temp.units,t[j].units);

strcpy(temp.tele,t[j].tele);

strcpy(t[j].name,t[j+1].name);

strcpy(t[j].units,t[j+1].units);

strcpy(t[j].tele,t[j+1].tele);

strcpy(t[j+1].name,temp.name);

strcpy(t[j+1].units,temp.units);

strcpy(t[j+1].tele,temp.tele);

}

if(flag==0)break; /*如果標志為0,說明沒有發生過交換循環結束*/

}

printf("sort sucess!!!\n"); /*顯示排序成功*/

}

/*快速查找,參數為結構體數組和記錄數*/

void qseek(ADDRESS t[],int n)

{

char s[20];

int l,r,m;

printf("\nPlease sort before qseek!\n"); /*提示確認在查找之前,記錄是否已排序*/

printf("please enter name for qseek\n"); /*提示輸入*/

scanf("%s",s); /*輸入待查找的姓名*/

l=0;r=n-1; /*設置左邊界與右邊界的初值*/

while(l=r) /*當左邊界=右邊界時*/

{

m=(l+r)/2; /*計算中間位置*/

if(strcmp(t[m].name,s)==0) /*與中間結點姓名字段做比較判是否相等*/

{

print(t[m]); /*如果相等,則調用print函數顯示記錄信息*/

return ; /*返回*/

}

if(strcmp(t[m].name,s)0) /*如果中間結點小*/

l=m+1; /*修改左邊界*/

else

r=m-1; /*否則,中間結點大,修改右邊界*/

}

if(lr) /*如果左邊界大于右邊界時*/

printf("not found\n"); /*顯示沒找到*/

}

/*復制文件*/

void copy()

{

char outfile[20]; /*目標文件名*/

int i,n;

ADDRESS temp[M]; /*定義臨時變量*/

FILE *sfp,*tfp; /*定義指向文件的指針*/

clrscr();/*清屏*/

if((sfp=fopen("record.txt","rb"))==NULL) /*打開記錄文件*/

{

printf("can not open file\n"); /*顯示不能打開文件信息*/

exit(1); /*退出*/

}

printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示信息*/

scanf("%s",outfile); /*輸入目標文件名*/

if((tfp=fopen(outfile,"wb"))==NULL) /*打開目標文件*/

{

printf("can not open file\n"); /*顯示不能打開文件信息*/

exit(1); /*退出*/

}

fscanf(sfp,"%d",n); /*讀出文件記錄數*/

fprintf(tfp,"%d",n);/*寫入目標文件數*/

fprintf(tfp,"\r\n"); /*寫入換行符*/

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

{

fscanf(sfp,"%20s%30s%10s\n",temp[i].name,temp[i].units,

temp[i].tele); /*讀入記錄*/

fprintf(tfp,"%-20s%-30s%-10s\n",temp[i].name,

temp[i].units,temp[i].tele); /*寫入記錄*/

fprintf(tfp,"\r\n"); /*寫入換行符*/

}

fclose(sfp); /*關閉源文件*/

fclose(tfp); /*關閉目標文件*/

printf("you have success copy file!!!\n"); /*顯示復制成功*/

}

好好參考一下啦,可能有些函數你還沒學到,找找書就行了。

c語言手機通訊錄 重謝

#includestdio.h struct Class {char *cname; //名字char *cphon; //電話號碼char *cuphon; //單位電話char *cmphon; //手機號碼char *cqq; //qq號碼char *cbday; //生日日期struct Class *node; //其余的自己可以加***** }; typedef struct Class Students; //通訊錄結構 typedef Students *Ps; Ps TcraseClsSt(Ps lina); // 催的操作Ps CraseClsSt(Ps lina,char *cname,char *cphon,char *cuphon,char *cmphon,char *cqq,char *cbday); //存過程void OutSmary(Ps lina); //輸出結果 void main() {Ps lina=NULL;lina=TcraseClsSt(lina);if(lina!=NULL) //如果lina為NULL是錯誤內存非配失敗{OutSmary(lina);}elseprintf("Error");getch(); } Ps TcraseClsSt(Ps lina) {int Cmd=0;char cname[100];char cphon[100];char cuphon[100];char cmphon[100];char cqq[100];char cbday[100];do{ printf("Please enter a name:");scanf("%s",cname); //提示并輸入數據printf("Enter the phone number:");scanf("%s",cphon);printf("Enter the unit telephone:");scanf("%s",cuphon);printf("Enter phone number:");scanf("%s",cmphon);printf("Enter the number qq:");scanf("%s",cqq);printf("Enter your date of birth:");scanf("%s",cbday);lina=CraseClsSt(lina,cname,cphon,cuphon,cmphon,cqq,cbday);//把數據存入鏈表 printf("Enter -1 to exit any exit:");scanf("%d",Cmd); } while(Cmd!=-1lina!=NULL);return lina; } Ps CraseClsSt(Ps lina,char *cname,char *cphon,char *cuphon,char *cmphon,char *cqq,char *cbday) //鏈表存入函數 {Ps merory;Ps linb;merory=(Ps)malloc(sizeof(Students));if(!merory){return NULL; //merory為NULL是返回零 NULL}merory-node=NULL;strcpy(merory-cname,cname); //用字符創拷貝函數 段錯午 在turbo c 編譯器可以通過 gcc可以用別的方法處理strcpy(merory-cphon,cphon);strcpy(merory-cuphon,cuphon);strcpy(merory-cmphon,cmphon);strcpy(merory-cqq,cqq);strcpy(merory-cbday,cbday);if(lina==NULL)return merory; linb=lina; while(linb-node!=NULL)linb=linb-node; linb-node=merory;return lina; } void OutSmary(Ps lina) //鏈表輸出函數 {while(lina!=NULL){printf("name:%s,Phone:%s,Unit Number:%s,Phone number:%s,qq No:%s,Date of Birth:%s\n",lina-cname,lina-cphon,lina-cuphon,lina-cmphon,lina-cqq,lina-cbday);lina=lina-node;} }

用c語言編一個查重程序

#include stdio.h

int lookup(char *str, char *key);

main()

{

char str[1024] = "asdfjad asdfh adsf adsf adsf adf adsfasdfkjasdf andsf akdf sdkf"

char key[32];

int pos[100];

printf("輸入要查詢的單詞: ");

scanf("%s", key);

lookup(str, key, pos);

printf("共重復了%d次\n,位置分別是:", pos[0]);

for(i = 1 ; i = pos[0]; i ++) {

printf("%d “, pos[i]);

}

printf("\n");

}

int lookup(char *str, char *key, int pos[])

{

int i, j;

pos[0] = 0; /* 記錄重復次數 */

for(i = 0; i strlen(str); i ++) {

if(key[0] == str[i]) {

for(j = 1; j strlen(key); j ++) {

if(key[j] != str[i+j])

break;

}

if(j == strlen(key)) { /* found */

pos[0] ++;

pos[pos[0]] = i;

i += j-1;

}

}

}

}

C語言程序設計——課程設計——通訊錄管理系統

/*10.3.2源程序*/

/******頭文件(.h)***********/

#include "stdio.h" /*I/O函數*/

#include "stdlib.h" /*標準庫函數*/

#include "string.h"/*字符串函數*/

#include "ctype.h" /*字符操作函數*/

#define M 50 /*定義常數表示記錄數*/

typedef struct /*定義數據結構*/

{

char name[20]; /*姓名*/

char units[30]; /*單位*/

char tele[10]; /*電話*/

}ADDRESS;

/******以下是函數原型*******/

int enter(ADDRESS t[]); /*輸入記錄*/

void list(ADDRESS t[],int n); /*顯示記錄*/

void search(ADDRESS t[],int n); /*按姓名查找顯示記錄*/

int delete(ADDRESS t[],int n); /*刪除記錄*/

int add(ADDRESS t[],int n); /*插入記錄*/

void save(ADDRESS t[],int n); /*記錄保存為文件*/

int load(ADDRESS t[]); /*從文件中讀記錄*/

void display(ADDRESS t[]); /*按序號查找顯示記錄*/

void sort(ADDRESS t[],int n); /*按姓名排序*/

void qseek(ADDRESS t[],int n); /*快速查找記錄*/

void copy(); /*文件復制*/

void print(ADDRESS temp); /*顯示單條記錄*/

int find(ADDRESS t[],int n,char *s) ; /*查找函數*/

int menu_select(); /*主菜單函數*/

/******主函數開始*******/

main()

{

int i;

ADDRESS adr[M]; /*定義結構體數組*/

int length; /*保存記錄長度*/

clrscr(); /*清屏*/

for(;;)/*無限循環*/

{

switch(menu_select()) /*調用主菜單函數,返回值整數作開關語句的條件*/

{

case 0:length=enter(adr);break;/*輸入記錄*/

case 1:list(adr,length);break; /*顯示全部記錄*/

case 2:search(adr,length);break; /*查找記錄*/

case 3:length=delete(adr,length);break; /*刪除記錄*/

case 4:length=add(adr,length); break; /*插入記錄*/

case 5:save(adr,length);break; /*保存文件*/

case 6:length=load(adr); break; /*讀文件*/

case 7:display(adr);break; /*按序號顯示記錄*/

case 8:sort(adr,length);break; /*按姓名排序*/

case 9:qseek(adr,length);break; /*快速查找記錄*/

case 10:copy();break; /*復制文件*/

case 11:exit(0); /*如返回值為11則程序結束*/

}

}

}

/*菜單函數,函數返回值為整數,代表所選的菜單項*/

menu_select()

{

char s[80];

int c;

gotoxy(1,25);/*將光標定為在第25行,第1列*/

printf("press any key enter menu......\n");/*提示壓任意鍵繼續*/

getch(); /*讀入任意字符*/

clrscr(); /*清屏*/

gotoxy(1,1);

printf("********************MENU*********************\n\n");

printf(" 0. Enter record\n");

printf(" 1. List the file\n");

printf(" 2. Search record on name\n");

printf(" 3. Delete a record\n");

printf(" 4. add record \n");

printf(" 5. Save the file\n");

printf(" 6. Load the file\n");

printf(" 7. display record on order\n");

printf(" 8. sort to make new file\n");

printf(" 9. Quick seek record\n");

printf(" 10. copy the file to new file\n");

printf(" 11. Quit\n");

printf("***********************************************\n");

do{

printf("\n Enter you choice(0~11):"); /*提示輸入選項*/

scanf("%s",s); /*輸入選擇項*/

c=atoi(s); /*將輸入的字符串轉化為整型數*/

}while(c0||c11); /*選擇項不在0~11之間重輸*/

return c; /*返回選擇項,主程序根據該數調用相應的函數*/

}

/***輸入記錄,形參為結構體數組,函數值返回類型為整型表示記錄長度*/

int enter(ADDRESS t[])

{

int i,n;

char *s;

clrscr(); /*清屏*/

printf("\nplease input num \n"); /*提示信息*/

scanf("%d",n); /*輸入記錄數*/

printf("please input record \n"); /*提示輸入記錄*/

printf("name unit telephone\n");

printf("------------------------------------------------\n");

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

{

scanf("%s%s%s",t[i].name,t[i].units,t[i].tele); /*輸入記錄*/

printf("----------------------------------------------\n");

}

return n; /*返回記錄條數*/

}

/*顯示記錄,參數為記錄數組和記錄條數*/

void list(ADDRESS t[],int n)

{

int i;

clrscr();

printf("\n\n*******************ADDRESS******************\n");

printf("name unit telephone\n");

printf("------------------------------------------------\n");

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

printf("%-20s%-30s%-10s\n",t[i].name,t[i].units,t[i].tele);

if((i+1)%10==0) /*判斷輸出是否達到10條記錄*/

{

printf("Press any key continue...\n"); /*提示信息*/

getch(); /*壓任意鍵繼續*/

}

printf("************************end*******************\n");

}

/*查找記錄*/

void search(ADDRESS t[],int n)

{

char s[20]; /*保存待查找姓名字符串*/

int i; /*保存查找到結點的序號*/

clrscr(); /*清屏*/

printf("please search name\n");

scanf("%s",s); /*輸入待查找姓名*/

i=find(t,n,s); /*調用find函數,得到一個整數*/

if(in-1) /*如果整數i值大于n-1,說明沒找到*/

printf("not found\n");

else

print(t[i]); /*找到,調用顯示函數顯示記錄*/

}

/*顯示指定的一條記錄*/

void print(ADDRESS temp)

{

clrscr();

printf("\n\n********************************************\n");

printf("name unit telephone\n");

printf("------------------------------------------------\n");

printf("%-20s%-30s%-10s\n",temp.name,temp.units,temp.tele);

printf("**********************end***********************\n");

}

/*查找函數,參數為記錄數組和記錄條數以及姓名s */

int find(ADDRESS t[],int n,char *s)

{

int i;

for(i=0;in;i++)/*從第一條記錄開始,直到最后一條*/

{

if(strcmp(s,t[i].name)==0) /*記錄中的姓名和待比較的姓名是否相等*/

return i; /*相等,則返回該記錄的下標號,程序提前結結束*/

}

return i; /*返回i值*/

}

/*刪除函數,參數為記錄數組和記錄條數*/

int delete(ADDRESS t[],int n)

{

char s[20]; /*要刪除記錄的姓名*/

int ch=0;

int i,j;

printf("please deleted name\n"); /*提示信息*/

scanf("%s",s);/*輸入姓名*/

i=find(t,n,s); /*調用find函數*/

if(in-1) /*如果in-1超過了數組的長度*/

printf("no found not deleted\n"); /*顯示沒找到要刪除的記錄*/

else

{

print(t[i]); /*調用輸出函數顯示該條記錄信息*/

printf("Are you sure delete it(1/0)\n"); /*確認是否要刪除*/

scanf("%d",ch); /*輸入一個整數0或1*/

if(ch==1) /*如果確認刪除整數為1*/

{

for(j=i+1;jn;j++) /*刪除該記錄,實際后續記錄前移*/

{

strcpy(t[j-1].name,t[j].name); /*將后一條記錄的姓名拷貝到前一條*/

strcpy(t[j-1].units,t[j].units); /*將后一條記錄的單位拷貝到前一條*/

strcpy(t[j-1].tele,t[j].tele); /*將后一條記錄的電話拷貝到前一條*/

}

n--; /*記錄數減1*/

}

}

return n; /*返回記錄數*/

}

/*插入記錄函數,參數為結構體數組和記錄數*/

int add(ADDRESS t[],int n)/*插入函數,參數為結構體數組和記錄數*/

{

ADDRESS temp; /*新插入記錄信息*/

int i,j;

char s[20]; /*確定插入在哪個記錄之前*/

printf("please input record\n");

printf("************************************************\n");

printf("name unit telephone\n");

printf("--------------------------------------------------\n");

scanf("%s%s%s",temp.name,temp.units,temp.tele); /*輸入插入信息*/

printf("------------------------------------------------\n");

printf("please input locate name \n");

scanf("%s",s); /*輸入插入位置的姓名*/

i=find(t,n,s); /*調用find,確定插入位置*/

for(j=n-1;j=i;j--) /*從最后一個結點開始向后移動一條*/

{

strcpy(t[j+1].name,t[j].name); /*當前記錄的姓名拷貝到后一條*/

strcpy(t[j+1].units,t[j].units); /*當前記錄的單位拷貝到后一條*/

strcpy(t[j+1].tele,t[j].tele); /*當前記錄的電話拷貝到后一條*/

}

strcpy(t[i].name,temp.name); /*將新插入記錄的姓名拷貝到第i個位置*/

strcpy(t[i].units,temp.units); /*將新插入記錄的單位拷貝到第i個位置*/

strcpy(t[i].tele,temp.tele); /*將新插入記錄的電話拷貝到第i個位置*/

n++; /*記錄數加1*/

return n; /*返回記錄數*/

}

/*保存函數,參數為結構體數組和記錄數*/

void save(ADDRESS t[],int n)

{

int i;

FILE *fp; /*指向文件的指針*/

if((fp=fopen("record.txt","wb"))==NULL) /*打開文件,并判斷打開是否正常*/

{

printf("can not open file\n");/*沒打開*/

exit(1); /*退出*/

}

printf("\nSaving file\n"); /*輸出提示信息*/

fprintf(fp,"%d",n); /*將記錄數寫入文件*/

fprintf(fp,"\r\n"); /*將換行符號寫入文件*/

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

{

fprintf(fp,"%-20s%-30s%-10s",t[i].name,t[i].units,t[i].tele);/*格式寫入記錄*/

fprintf(fp,"\r\n"); /*將換行符號寫入文件*/

}

fclose(fp);/*關閉文件*/

printf("****save success***\n"); /*顯示保存成功*/

}

/*讀入函數,參數為結構體數組*/

int load(ADDRESS t[])

{

int i,n;

FILE *fp; /*指向文件的指針*/

if((fp=fopen("record.txt","rb"))==NULL)/*打開文件*/

{

printf("can not open file\n"); /*不能打開*/

exit(1); /*退出*/

}

fscanf(fp,"%d",n); /*讀入記錄數*/

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

fscanf(fp,"%20s%30s%10s",t[i].name,t[i].units,t[i].tele); /*按格式讀入記錄*/

fclose(fp); /*關閉文件*/

printf("You have success read data from file!!!\n"); /*顯示保存成功*/

return n; /*返回記錄數*/

}

/*按序號顯示記錄函數*/

void display(ADDRESS t[])

{

int id,n;

FILE *fp; /*指向文件的指針*/

if((fp=fopen("record.txt","rb"))==NULL) /*打開文件*/

{

printf("can not open file\n"); /*不能打開文件*/

exit(1); /*退出*/

}

printf("Enter order number...\n"); /*顯示信息*/

scanf("%d",id); /*輸入序號*/

fscanf(fp,"%d",n); /*從文件讀入記錄數*/

if(id=0idn) /*判斷序號是否在記錄范圍內*/

{

fseek(fp,(id-1)*sizeof(ADDRESS),1); /*移動文件指針到該記錄位置*/

print(t[id]); /*調用輸出函數顯示該記錄*/

printf("\r\n");

}

else

printf("no %d number record!!!\n ",id); /*如果序號不合理顯示信息*/

fclose(fp); /*關閉文件*/

}

/*排序函數,參數為結構體數組和記錄數*/

void sort(ADDRESS t[],int n)

{

int i,j,flag;

ADDRESS temp; /*臨時變量做交換數據用*/

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

{

flag=0; /*設標志判斷是否發生過交換*/

for(j=0;jn-1;j++)

if((strcmp(t[j].name,t[j+1].name))0) /*比較大小*/

{

flag=1;

strcpy(temp.name,t[j].name); /*交換記錄*/

strcpy(temp.units,t[j].units);

strcpy(temp.tele,t[j].tele);

strcpy(t[j].name,t[j+1].name);

strcpy(t[j].units,t[j+1].units);

strcpy(t[j].tele,t[j+1].tele);

strcpy(t[j+1].name,temp.name);

strcpy(t[j+1].units,temp.units);

strcpy(t[j+1].tele,temp.tele);

}

if(flag==0)break; /*如果標志為0,說明沒有發生過交換循環結束*/

}

printf("sort sucess!!!\n"); /*顯示排序成功*/

}

/*快速查找,參數為結構體數組和記錄數*/

void qseek(ADDRESS t[],int n)

{

char s[20];

int l,r,m;

printf("\nPlease sort before qseek!\n"); /*提示確認在查找之前,記錄是否已排序*/

printf("please enter name for qseek\n"); /*提示輸入*/

scanf("%s",s); /*輸入待查找的姓名*/

l=0;r=n-1; /*設置左邊界與右邊界的初值*/

while(l=r) /*當左邊界=右邊界時*/

{

m=(l+r)/2; /*計算中間位置*/

if(strcmp(t[m].name,s)==0) /*與中間結點姓名字段做比較判是否相等*/

{

print(t[m]); /*如果相等,則調用print函數顯示記錄信息*/

return ; /*返回*/

}

if(strcmp(t[m].name,s)0) /*如果中間結點小*/

l=m+1; /*修改左邊界*/

else

r=m-1; /*否則,中間結點大,修改右邊界*/

}

if(lr) /*如果左邊界大于右邊界時*/

printf("not found\n"); /*顯示沒找到*/

}

/*復制文件*/

void copy()

{

char outfile[20]; /*目標文件名*/

int i,n;

ADDRESS temp[M]; /*定義臨時變量*/

FILE *sfp,*tfp; /*定義指向文件的指針*/

clrscr();/*清屏*/

if((sfp=fopen("record.txt","rb"))==NULL) /*打開記錄文件*/

{

printf("can not open file\n"); /*顯示不能打開文件信息*/

exit(1); /*退出*/

}

printf("Enter outfile name,for example c:\\f1\\te.txt:\n"); /*提示信息*/

scanf("%s",outfile); /*輸入目標文件名*/

if((tfp=fopen(outfile,"wb"))==NULL) /*打開目標文件*/

{

printf("can not open file\n"); /*顯示不能打開文件信息*/

exit(1); /*退出*/

}

fscanf(sfp,"%d",n); /*讀出文件記錄數*/

fprintf(tfp,"%d",n);/*寫入目標文件數*/

fprintf(tfp,"\r\n"); /*寫入換行符*/

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

{

fscanf(sfp,"%20s%30s%10s\n",temp[i].name,temp[i].units,

temp[i].tele); /*讀入記錄*/

fprintf(tfp,"%-20s%-30s%-10s\n",temp[i].name,

temp[i].units,temp[i].tele); /*寫入記錄*/

fprintf(tfp,"\r\n"); /*寫入換行符*/

}

fclose(sfp); /*關閉源文件*/

fclose(tfp); /*關閉目標文件*/

printf("you have success copy file!!!\n"); /*顯示復制成功*/

}

C語言編程 字符串查重

當然能了,它的原理是字符匹配。只要是字符就會查出來,你可以試著把它變成圖片,或者把文字的前后順序換一下,更或者換一種說話。


分享名稱:c語言通訊錄查重比較函數,c語言查重算法
URL網址:http://www.xueling.net.cn/article/dsgjghd.html

其他資訊

在線咨詢
服務熱線
服務熱線:028-86922220
TOP
主站蜘蛛池模板: 狠狠色噜噜狠狠狠狠2021 | 亚洲一区二区精品 | 青青草视频在线免费播放 | av第一福利在线导航 | 国内久久 | 日韩精品在线免费视频 | 婷婷五月六月综合缴情 | 精品久久久一 | 一本色道久久综合狠狠躁的推荐 | 四虎精品一区二区永久在线观看 | 99久久精品国产一区二区野战 | 99精品99| 亚洲天堂2017无码中文 | 欧美日韩国产一区二区三区在线观看 | AV大片在线无码永久免费 | 人妻少妇伦在线无码 | 欧美日韩国产一区二区三区在线观看 | 国产精品麻豆aⅴ人妻 | 欧美日韩亚洲精品内裤 | 国产精品午夜福利片不卡 | 精品国产乱码久久久久久a丨 | 国产69久久精品成人看动漫 | 国产9页| 97就去干 | 亚洲黄色网络 | 精品久久久久久无码免费 | 免费播放大片免费观看视频 | 文中字幕一区二区三区视频播放 | 色77影院 | 九九热只有精品 | 男人猛躁女人免费 | 一区二区高清视频 | 一级片在线视频 | 国产在线观看精品一区二区三区 | 亚洲AV无码一区二区三区国产 | 顶臀精品视频www | 国产成人一区二区三区在线 | 性生活久久久 | 国产中文日韩欧美 | 狠狠操操操 | 奇米色欧美一区二区三区 |