c语言delnum函数 c语言dlsym函数

用C语言编写的关于文件的行操作程序(行插入,行删除,活区切换,活区显示)

#define NULL 0

江苏ssl适用于网站、小程序/APP、API接口等需要进行数据传输应用场景,ssl证书未来市场广阔!成为创新互联的ssl证书销售渠道,可以享受市场价格4-6折优惠!如果有意向欢迎电话联系或者加微信:13518219792(备注:SSL证书合作)期待与您的合作!

#define OK 0

#include stdio.h

#include stdlib.h

#include string.h

#include ctype.h

#include conio.h

typedef struct text

{

char string[80];//存储每一行的元素

struct text *next;//指向后一个节点的指针

struct text *pre;//指向前一个节点的指针

int num;//每一行元素的长度

int flat;//确定此行是否被删除的标志

}text;

FILE *fp,*out;//fp是执行被打开的文件,out指向被写入的文件

text *head;//链表的头指针

int n=0,sum,delnum,xiugai=0,page=0;

//修改用来指示文件是否被修改过,如果修改过才回存盘。page用来计算显示的

//页数.delnum用来存储被删除的字节数,sum存储一页的总字节数

void byebye()//没有具体用处,只是写着玩的,在屏幕上显示一个bye

{

puts("\t\t\t******** * * ********");

puts("\t\t\t* * * * * ");

puts("\t\t\t* * * * * ");

puts("\t\t\t* * * * * ");

puts("\t\t\t******** * ********");

puts("\t\t\t* * * * ");

puts("\t\t\t* * * * ");

puts("\t\t\t* * * * ");

puts("\t\t\t******** * ********");

}

void HELP()//帮助函数,显示一些命令的格式

{

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

printf("\t** 打开文件: o行号文件名回车 **\n");

printf("\t** 行插入格式: i行号回车文本回车 **\n");

printf("\t** 行删除格式: d行号1[空格行号2]回车 **\n");

printf("\t** 活区切换格式: n回车 **\n");

printf("\t** 活区显示格式: p回车 **\n");

printf("\t** 注意:在执行所有命令前必须先用o命令打开文件,并 **\n");

printf("\t** 用p命令显示出来!!! **\n");

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

system("pause");

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

}

void ABOUT()//也是写着玩的

{

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

printf("\t\t** 作者:BLACKCAT **\n");

printf("\t\t** 单位:ZZU **\n");

printf("\t\t** E-mail:blackcat242@etang.com **\n");

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

system("pause");

system("cls");

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

}

void Createlist()//建立一个十个节点的链表,是文本中的一页

{

text *p1,*p2;

p1=p2=(text *)malloc(sizeof(text));

head=NULL;

while(n10)

{

n=n+1;

if(n==1) head=p1;

else

{

p2-next=p1;

p1-pre=p2;

p1-flat=0;

}

p2=p1;

p1=(text *)malloc(sizeof(text));

}

p2-next=NULL;

}

void freemem()//释放链表所占的内存

{

text *p;

for(p=head;head!=NULL;)

{

head=p-next;

free(p);

p=head;

}

}

int Openfiles()//打开文件的函数

{

char name[30],outname[30];

puts("请输入要打开的文件名:");

scanf("%s",name);

if((fp=fopen(name,"r+"))==NULL)

{

printf("打不开原文件! \n");

exit(0);

}

puts("请输入要写入的文件名:");

scanf("%s",outname);

if((out=fopen(outname,"w+"))==NULL)

{

printf("打不开目标文件!\n");

exit(0);

}

return 0;

}

int display()//从文件中读入到链表中,并显示出来

{

int i;

char conti='y';

text *p;

while((!feof(fp))(conti=='y'||conti=='Y'))

{

page++;

printf("\t\t第%d页\n",page);

for(i=0,p=head,sum=0;(i10)(!feof(fp));i++,p=p-next)

{

fgets(p-string,sizeof(p-string),fp);

puts(p-string);

p-flat=1;

p-num=strlen(p-string);

sum=sum+p-num;

}

puts("Continue?(Y/N):");

conti=getche();

if(feof(fp))

{

puts("\n文件已经结束!");

return 0;

}

}

return 0;

}

int saveanddisplay(int hang)//命令n执行的函数,用来将活区的内容显示并读入下一页内容

{

int i,endflat=0;

char conti='y';

text *p=NULL;

page++;

for(i=0,p=head;ihang;i++,p=p-next) //将活区写入文件

if(p-flat==1)

{

fputs(p-string,out);

p-flat=0;

}

if(!feof(fp))

printf("\t\t第%d页\n",page);

for(i=0,p=head,sum=0;(i10)(!feof(fp));i++,p=p-next)//从文件读入活区

if(fgets(p-string,sizeof(p-string),fp))

{

puts(p-string);

p-flat=1;

p-num=strlen(p-string);

sum=sum+p-num;

}

if(feof(fp))

printf("文件已经结束!");

return 0;

}

int saveall()//退出编辑函数后执行的函数,将所有的内容存盘

{

int i,endflat=0;

char conti='y';

text *p;

for(i=0,p=head;i10;i++,p=p-next) //将活区写入文件

if(p-flat==1)

{

fputs(p-string,out);

p-flat=0;

}

while(!feof(fp))//将其余的内容写入文件

fputc(fgetc(fp),out);

return 0;

}

int del()//删除d命令对应的函数,用来删min-max中的行,用结构体中的flat表示是否被删除

{

text *p1,*p2,*p3;

int min,max,i;

xiugai=1;

scanf("%d %d",min,max);

if(head==NULL)

{

printf("\nlist null!\n");

return 0;

}

p1=p2=head;

for(i=0;imin-1;i++)/*找到要删除的第一行*/

p1=p1-next;

for(i=0;imax;i++)/*找到要删除的最后一行*/

p2=p2-next;

for(delnum=0;p1!=p2;p1=p1-next)/*删除中间的节点,将flat赋值0*/

{

p1-flat=0;

delnum=delnum+p1-num;

}

for(i=0,p3=head;i10;i++,p3=p3-next)//显示删除后的结果

if(p3-flat==1)

puts(p3-string);

saveanddisplay(10);//将删除后的结果存盘并显示下一页内容(十行)

xiugai=1;

return 0;

}

int insert()//插入i命令对应的函数,在i行后插入文本

{

int hang,i,increhang=1,number=1;

text *p,*p1,*p2;

xiugai=1;

scanf("%d",hang);

p=p1=NULL;

for(i=0,p1=head;ihang-1;i++,p1=p1-next);//找到要插入行的前一列

p=(text *)malloc(sizeof(text));//为插入行分配空间

p-flat=1;

p-next=p1-next;//从此行向下四行将插入行插入到链表中

p-pre=p1;

p1-next-pre=p;

p1-next=p;

p-string[0]=getchar();

p-string[0]=getchar();

for(i=1;(i80)(p-string[i-1]!='^');i++)

{

p-string[i]=getchar();

if((i+1==80)(p-string[i]!='^'))//如果插入的内容超过一行

{ //的容量,则分配下一行空间

p1=p; //并将其连入链表

p=(text *)malloc(sizeof(text));

p-flat=1;

p-next=p1-next;

p-pre=p1;

p1-next-pre=p;

p1-next=p;

i=0;

increhang++;

}

p-num=i;

}

p-string[i-1]='\n';

p-string[i]='\0';

puts("修改后的链表:");

for(p2=head;p2!=NULL;p2=p2-next)//显示出修改后的链表

puts(p2-string);

saveanddisplay(10+increhang);//将修改后的链表存盘并显示下一页内容

xiugai=1;

return 0;

}

int EDIT()//编辑函数,用来接受处理编辑命令

{

char cmd;

do

{

cmd=getchar();

printf("\n请输入命令(按E键退出):");

cmd=getchar();

switch(cmd)

{

case 'e':

case 'E':

if(xiugai==1)

saveall();

freemem();

if(fp) fclose(fp);

if(out) fclose(out);

system("cls");

return 0;

case 'o':

case 'O':

Openfiles();

break;

case 'p':

case 'P':

Createlist();

display();

break;

case 'n':

case 'N':

saveanddisplay(10);

break;

case 'd':

case 'D':

del();

break;

case 'i':

case 'I':

insert();

break;

default:printf("\n\n\n!!!输入错误!!!");

}

}while(cmd!='e'cmd!='E');

return 0;

}

int main()//主函数,用来接受命令

{

char cmd;

do

{

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

printf("\t\t** 1 EDIT **\n");

printf("\t\t** 2 HELP **\n");

printf("\t\t** 3 ABOUT **\n");

printf("\t\t** 4 EXIT **\n");

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

printf("\n\n请选择1,2,3,4:");

cmd=getche();

switch(cmd)

{

case '4' : system("cls"); byebye(); break;

case '2' : system("cls"); HELP(); cmd=0; break;

case '3' : system("cls"); ABOUT(); cmd=0; break;

case '1' : EDIT(); cmd=0; break;

default : printf("\n\n\n!!!输入错误!!!\n");

}

}while(cmd!='4');

return 0;

}

用C语言编写学生信息管理程序(给出五个主要函数就OK啦!)

/*接上一楼*/

struct

Student

*create()

/*create函数定义,此函数实现创建单向动态链表*/

{

struct

Student

*head=NULL,*p1,*p2;

/*head,链表的头指针;*p1,*p2,中间指针变量*/

puts("\n现在请输入学院名:");

scanf("%s",college);

puts("\n年级:");

scanf("%s",grade);

puts("\n专业和班级:");

scanf("%s",classname);

puts("\n下面请按提示依次输入数据:\n(如果要结束输入,请输入学号0)");

p1=p2=(struct

Student

*)malloc(LEN);

puts("输入第一个学生的学号:");

scanf("%ld",p1-num);

puts("输入此学生成绩:\n英语:");

scanf("%f",p1-score.english);

puts("数学:");

scanf("%f",p1-score.math);

puts("计算机:");

scanf("%f",p1-score.computer);

total_and_aver(p1);/*计算总分和平均分*/

p1-grade=mark_grade(p1);

for(;p1-num!=0;)

{

len++;

if(len==1)

head=p1;

else

p2-next=p1;

p2=p1;

p1=(struct

Student

*)malloc(LEN);

puts("输入下一个学生的学号:");

scanf("%ld",p1-num);

puts("输入此学生成绩:\n英语:");

scanf("%f",p1-score.english);

puts("数学:");

scanf("%f",p1-score.math);

puts("计算机:");

scanf("%f",p1-score.computer);

total_and_aver(p1);/*计算总分和平均分*/

p1-grade=mark_grade(p1);

}

p2-next=NULL;

return

(head);

}

struct

Student

*del(struct

Student

*head,long

del_num)

/*del函数定义,此函数实现从现有链表中删除一个结点*/

{

struct

Student

*p1,*p2;

if(head==NULL)

puts("空表,没有任何数据记录。\n");

else

{

for(p1=head;!(del_num==p1-num||p1-next==NULL);p2=p1,p1=p1-next);

if(del_num==p1-num)

{

if(p1==head)head=p1-next;

else

p2-next=p1-next;

printf("学号为%ld学生的数据删除成功。\n",del_num);

--len;

}

else

printf("未找到学号为%ld学生的记录。\n",del_num);

}

return

(head);

}

struct

Student

*insert(struct

Student

*head,struct

Student

*new_student)

/*insert函数定义,此函数实现向现有链表中插入一个结点或覆盖相同学号的数据*/

{

struct

Student

*p0=new_student,*p1=head,*p2;

char

control;

if(head==NULL)

{

head=p0;

p0-next=NULL;

puts("数据插入成功。\n");

}

else

{

for(;((*p0).num(*p1).num)(p1-next!=NULL);p2=p1,p1=p1-next);

if((*p0).num==(*p1).num)

{

printf("已经存在一个学号为%ld的学生的数据,要覆盖原有数据吗?\n输入

Y

=覆盖原有数据\n输入其它=保留原有数据\n",p0-num);

FFLUSH;

scanf("%c",control);

FFLUSH;

switch

(control)

{

case

'Y':

case

'y':if(p1==head){head=p0;p0-next=p1-next;}

else

{p2-next=p0;p0-next=p1-next;}

puts("数据已经更新\n");break;

default:break;

}

len--;

}

else

if((*p0).num(*p1).num)

{

if(p1==head)head=p0;

else

p2-next=p0;

p0-next=p1;

puts("数据插入成功。\n");

}

else

{

p1-next=p0;

p0-next=NULL;

puts("数据插入成功。\n");

}

}

++len;

return

(head);

}

struct

Student

*sort(struct

Student

*head)

/*sort函数定义,此函数实现对链表中的数据按照平均分高低排序*/

{

struct

Student

*p1,*p2;

for(p1=head;p1-next!=NULL;p1=p1-next)

for(p2=p1-next;p2!=NULL;p2=p2-next)

{

if(p1-score.averagep2-score.average)

{

SWAP(p1-num,p2-num);

SWAP(p1-grade,p2-grade);

SWAP(p1-score.english,p2-score.english);

SWAP(p1-score.math,p2-score.math);

SWAP(p1-score.computer,p2-score.computer);

SWAP(p1-score.total,p2-score.total);

SWAP(p1-score.average,p2-score.average);

}

}

return

head;

}

/*接下一楼*/

C语言中删除一个数组元素

如果数组里全是3 那我输入要删除的3之后 楼主想要一个什么结果呢

是9个3 还是一个元素也不输出?

下面的程序可能能实现楼主的意思

#includestdio.h

void main()

{

int a[10]={1,3,7,61,86,12,75643,8989,1,3},n,i;

printf("input the number to delete:");

scanf("%d",n);

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

if(a[i]!=n)

printf("%d ",a[i]);

}

萌新求问C语言函数int StrToInt(*s){.....}应该怎么写?

int delnum(char s[], int *p)

{

int i,n,j;

*p = NULL;

n=strlen(s);

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

if(!(s[i]='0's[i]='9'))

s[j++]=s[i];

else

*p += s[i]-'0';

s[j]='\0';

return n-strlen(s);

}

void main()

{

char item[80] = "my2009xy3com+";

int n,count;

count=delnum(item,n);

printf("%s,count=%d,sum=%d",item,count,n);

system("pause");

}


分享名称:c语言delnum函数 c语言dlsym函数
转载来源:http://azwzsj.com/article/doscodd.html