C語言實現簡單的文本編輯器
本文實例為大傢分享瞭C語言實現簡單的文本編輯器的具體代碼,供大傢參考,具體內容如下
預期實現三個功能,第一,可以對指定的行輸入字符串;第二,刪除指定行的字符串;第三,顯示編輯器的行數和內容。
我們通過塊鏈結構來實現本程序。“塊”的含義是每個塊中可以存放多個字符,“鏈”的含義是塊與塊之間通過鏈表結構進行連接。
IDE : Code::Blocks 17.12
Compiler : GNU GCC Compiler
/*塊鏈結構實現簡單的文本編輯器*/ #include <stdio.h> #include <stdlib.h> #define MAX 100 void Init(); //初始化編輯器 void input(); //對指定的行進行輸入,#號結束 void Delline(); //刪除指定的行 void List(); //顯示文本編輯器的內容 int Menu(); //列出選擇菜單並進行選擇 //定義存放字符串的節點,塊鏈結構 typedef struct node{ char data[50]; struct node *next; }strnode; //定義每行頭節點 typedef struct head{ int number; //行號 int length; //字符串的長度 strnode * next; }headnode; //定義有100行 headnode Head[MAX]; //函數Init()實現每行頭節點的初始化 void Init(){ int i; for(i=0;i<MAX;++i){ Head[i].length=0; } } //函數Menu()實現選擇菜單 int Menu(){ int i; i=0; printf("-------------\n"); printf("1. Input\n"); printf("2. Delete\n"); printf("3. List\n"); printf("4. Exit\n"); printf("-------------\n"); while(i<=0 || i>4){ printf("please choose\n"); scanf("%d",&i); } return i; } //函數input(),向指定行中輸入字符串 void input(){ strnode * p; int i,j,LineNum; char ch; while(1){ j=-1; printf("input the number of line(0~100),101-exit:\n"); scanf("%d",&LineNum); //輸入要寫入的行號 if(LineNum<0 || LineNum>=MAX){ return; } printf("please input,#-end\n"); i=LineNum; Head[i].number=LineNum; Head[i].next=(strnode *)malloc(sizeof(strnode)); p=Head[i].next; p->next=NULL; ch=getchar(); while(ch!='#'){ ++j; if(j>=50){ //如果字符串長度超過50,需要再分配一個節點空間 p->next=(strnode *)malloc(sizeof(strnode)); p->next->next=NULL; p=p->next; //p指向新分配的節點 } p->data[j%50]=ch; //將輸入的字符放入data中 ch=getchar(); } Head[i].length=j+1; //行的長度,以字符為單位 } } //函數Delline()實現對指定行的刪除 void Delline(){ strnode * p,*q; int i,LineNum; while(1){ printf("input the number of line which do you want to delete(0~100),101-exit:\n"); scanf("%d",&LineNum); //輸入要刪除的行號 if(LineNum<0 || LineNum>=MAX){ return; } i=LineNum; p=Head[i].next; if(Head[i].length>0){ while(p!=NULL){ q=p->next; free(p); p=q; } Head[i].length=0; Head[i].number=0; } } } //函數List()將輸入的內容顯示在屏幕上 void List(){ strnode *p; int i,j,m,n; for(i=0;i<MAX;++i){ if(Head[i].length>0){ printf("line%d",Head[i].number); n=Head[i].length; m=1; p=Head[i].next; for(j=0;j<n;++j){ if(j>=50*m){ //以50為基準,超過一個則指向下一個節點 p=p->next; ++m; //節點個數 }else{ printf("%c",p->data[j%50]); //將節點中內容輸出 } } printf("\n"); } } printf("\n"); } int main() { int sel; Init(); //初始化編輯器 while(1){ sel=Menu(); switch(sel){ //對輸入的數字進行選擇 case 1: input(); break; case 2: Delline(); break; case 3: List(); break; case 4: exit(0); } } return 0; }
測試運行結果如下:
以上就是本文的全部內容,希望對大傢的學習有所幫助,也希望大傢多多支持WalkonNet。