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。

推薦閱讀: