C言語で簡単なテキストエディタを実現します。
本論文の実例はC言語の簡単なテキストエディタの具体的なコードを共有しています。参考にしてください。具体的な内容は以下の通りです。
三つの機能が期待されています。第一に、指定された行に文字列を入力することができます。第二に、指定された行の文字列を削除します。第三に、エディタの行数と内容を表示します。
私たちはブロックチェーン構造により本プログラムを実現します。ブロックとは、各ブロックに複数の文字を格納することができるという意味であり、「鎖」とはブロックとブロックとの間をリンク構造で接続することを意味する。
IDE:Code:Blocks 17.12
Compler:GNU GCC Copiler
以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。
三つの機能が期待されています。第一に、指定された行に文字列を入力することができます。第二に、指定された行の文字列を削除します。第三に、エディタの行数と内容を表示します。
私たちはブロックチェーン構造により本プログラムを実現します。ブロックとは、各ブロックに複数の文字を格納することができるという意味であり、「鎖」とはブロックとブロックとの間をリンク構造で接続することを意味する。
IDE:Code:Blocks 17.12
Compler:GNU GCC Copiler
/* */
#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("-------------
");
printf("1. Input
");
printf("2. Delete
");
printf("3. List
");
printf("4. Exit
");
printf("-------------
");
while(i<=0 || i>4){
printf("please choose
");
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:
");
scanf("%d",&LineNum); //
if(LineNum<0 || LineNum>=MAX){
return;
}
printf("please input,#-end
");
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:
");
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("
");
}
}
printf("
");
}
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;
}
テストの実行結果は以下の通りです。以上が本文の全部です。皆さんの勉強に役に立つように、私たちを応援してください。