当前位置:首页 » 编程语言 » 数据结构c语言源代码

数据结构c语言源代码

发布时间: 2024-07-28 17:22:33

c语言数据结构(考题,测试你的能力)--编写源代码

考考自己吧
人不能总能依靠别人.

㈡ 数据结构:产品进销存管理系统的源代码(c语言或c++的)

&(p->salesquantity),&(p->salestime).year),&((p->salestime).month),&((p->salestime).day)); p->nextproct=q->nextproct;
q->nextproct=p;
q=p
}
}
return ok;
}//ProctInsert
void ProQuantity_add(sqmountlink&L,char pkindname 1[],char pname 1[],int n)
{//添加顺序表挂接链表的某产品的总量,且需添加的产品总量为n
int i,k;
plinklist p;
for(i=0;i<L.length;i++)
{
if(strcmp(L.kindelem[i]).pkindname,pkindname 1)!=0)
continue;
else
break;
}
if(i<L.length)
{
for(p=L.kindelem[i].firstproct;p!=NULL;p=p->nextproct)
{
k=strcnp(p->pname.pname);
if(k==0)
{
p->totalquantity=p->totalquantity+n;
printf("查看添加后产品的各项输出:%s %d%d,%d %d %d,%d,%d\n",p-pname,p->totalquantity,(p->goodsdate).year,(p->goodsdate).month,(p->goods).day,
p->salequanlity,(p->salestime).year,(p->salestime).month,(p->salestime).day);
}
}
}
}//ProQuantity_add
void Visit(sqmountlink&L,char pkindname3[],char pname3[])
{//在顺序表挂接链表L中,查询属于某产品类的某产品的各项信息
int i,k;
plinklist p;
for(i=0;i<L.length;i++)
{
if(strcmp((L.kindelem[i]),pkindname.pkindname3)!=0)
continue
else
break;
}
if(i<L.length)
{
for(p=L.kindelem[i].firstprodicy;p!=NULL;p=p->nextprocy)
{
k=strcmp(p->pname.pname3);
if(k==0)
break;
}
if(k!=0)
printf("此产品不存在:\n")
else
{
printf("输出带查询产品的各项信息:\n");
printf("%s %s %d %d,%d,%d %d %d,%d,%d\n",(L.kindelem[i]).pkindname,p->pname,p->totalquantity,(p->goodsdate).year,(p->goodsdate).month,(p->goodsdate).day,
p->salequantity,(p->salestime).year,(p->salestime).month,(p->salestime).day);
}
}
}//Visit
void DisplayList(sqmountlink&L)
{//显示各产品所属产品类,产品名称、产品总量,进货日期,销出数量,销售时间
int i;
plinklist p;
printf("产品类 产品 进货日期 销出数量 销售时间\n")
for(i=0;i<L.length;i++)
{
if(!(L.kindelem[i],firstproct))
printf("%s\n",(L.kindelem[i]).pkindname);
for(p=L.kindelem[i].firstproct;p;p=p->nextproct)
printf("%s %s %d %d,%d,%d %d %d,%d,%d \n",(L.kindelem[i]).pkindname,p->pname,p->totalquantity,(p->goodsdate).year,(P->goodsdate).month,(p->goodsdate).day,p->salesquantity,(p->salestime).year,(p->salestime).month,(p->salestime).day);
}
}//DisplayList
void DestoryMountList(sqmountlink&L)
{//销毁已存在的顺序表挂接链表L
int i;
kindlnode *p;
for(i=L.length;i>=0;
{
p=&(L.kindelem[i]);
if(*p).firstproct==NULL)
free(p);
else
{
while((*p).firstproct;q->nextproct;q=q->nextproct);
free(q);
}
free(q);
}
}
}//DestroyMountList
void menu_operation()
{//操作菜单
printf("----输入所要执行操作:-------\n")
printf("----产品类的添加:1------\n");
printf("----产品的添加:2-----\n");
printf("----产品数量的添加:3-----\n");
printf("----查询每种产品所属产品类,产品总量,进货日期,销出数量,销售时间:4-----------\n")
printf("----释放L所占内存空间,退出程序:0-----\n");
}//menu_operation
/*--------------主程序-------------*/
void main(void)
{
int order,
int i,n;
char a[30];
char b[30];
sqmountlink L;
InitMountList(L);
printf("-----创建初始的产品类、产品顺序表挂接链表L-----\n");
CreatMuntList(L);
DisplayList(L);
printf("-----初始的产品类、产品顺序表挂接链表L创建完成-----\n");
menu_operation();
loop:
printf("输入命令:");
scanf("%d",&order);
switch(order)
{
case 1:
printf("需添加产品类的个数:");
scanf("%d",&i);
kindinsert(L,i);
printf("输出修改后的产品库存管理表:\n");
DisplayList(L);
goto loop;
case 2:
printf("需添加产品所属产品类的名称:")
scanf("%s",&a);
printf("需向此产品类添加产品的个数:");
scanf("%d",&i);
ProctInsert(L,a,i);
printf("输出修改后的产品库存管理表:\n");
DisplayList(L);
goto loop;
case 3:
printf("输入需添加数量的产品所属产品类的名称:");
scanf("%s",&a);
printf("输入需添加数量的产品的名称:");
scanf("%d",&n);
ProQuantity_add(L,a,b,n);
printf("输出修改后的产品库存管理表:\n");
DisplayList(L);
goto loop ;
case 4:
printf("输入待查询产品所属产品类的名称:");
scanf("%s",&b);
printf("输入待查询产品的名称:");
scanf(%s",&b);
Visit(L<a,b);
goto loop;
case ():
DestroyMountList(L);
exit(0);
}
}

㈢ C语言编程-数据结构课程设计-文本编辑器,已经提供代码,若干问题

这是tongji university online judge的一道题,现在这个题库已经没有了,我把原题贴出来,你就知道这个程序什么意思了
Problem
一个简单的行编辑程序的功能是:接受用户从终端输入的程序或数据,并存入用户的数据区。

由于用户在终端上进行输入时,不能保证不出差错,因此,若在编辑程序中,“每接受一个字符即存入用户数据区”的做法显然不是最恰当的。较好的做法是,设立一个输入缓冲区,用以接受用户输入的一行字符,然后逐行存入用户数据区。允许用户输入出差错,并在发现有误时可以及时更正。例如,当用户发现刚刚键入的一个字符是错的时,可补进一个退格符"#",以表示前一个字符无效;

如果发现当前键入的行内差错较多或难以补救,则可以键入一个退行符"@",以表示当前行中的字符均无效。

如果已经在行首继续输入'#'符号无效。

Input
输入一个多行的字符序列。但行字符总数(包含退格符和退行符)不大于250。

Output
按照上述说明得到的输出。

Sample Input

whli##ilr#e(s#*s)

outcha@putchar(*s=#++);

Sample Output

while(*s)

putchar(*s++);

㈣ c璇瑷鏁版嵁缁撴瀯鍗曢摼琛ㄧ殑鍒濆嫔寲 鎻掑叆 阌姣 鍏幂礌镄勫彇鍑 鍒犻櫎 镎崭綔 姹傝︾粏C婧愪唬镰 璋㈣阿銆伞伞伞

鍗曢摼琛ㄥ姛鑳藉ぇ鍏锛屽樋鍢
#include <stdio.h>
#include <stdlib.h>

typedef struct node
{
int nDate;
struct node *pstnext;
}Node;
//阈捐〃杈揿嚭
void output(Node *head)
{
Node *p = head->pstnext;
while(NULL != p)
{
printf("%d ", p->nDate);
p = p->pstnext;
}
printf("\r\n");
}
//阈捐〃寤虹珛
Node* creat()
{
Node *head = NULL, *p = NULL, *s = NULL;
int Date = 0, cycle = 1;
head = (Node*)malloc(sizeof(Node));
if(NULL == head)
{
printf("鍒嗛厤鍐呭瓨澶辫触\r\n");
return NULL;
}
head->pstnext = NULL;

p = head;
while(cycle)
{
printf("璇疯緭鍏ユ暟鎹涓斿綋杈揿叆鏁版嵁涓0镞剁粨𨱒熻緭鍏\r\n");
scanf("%d", &Date);
if(0 != Date)
{
s = (Node*)malloc(sizeof(Node));
if(NULL == s)
{
printf("鍒嗛厤鍐呭瓨澶辫触\r\n");
return NULL;
}
s->nDate = Date;
p->pstnext = s;
p = s;
}
else
{
cycle = 0;
}
}
p->pstnext = NULL;
return(head);
}
//鍗曢摼琛ㄦ祴闀
void length(Node *head)
{
Node *p = head->pstnext;
int j=0;
while(NULL != p)
{
p = p->pstnext;
j++;
}
printf("%d\r\n", j);
}
//阈捐〃鎸夊兼煡镓
void research_Date(Node *head, int date)
{
Node *p;
int n=1;
p = head->pstnext;
while(NULL != p && date != p->nDate)
{
p = p->pstnext;
++n;
}
if(NULL == p)
{
printf("阈捐〃涓娌℃湁镓惧埌璇ュ");
}else if(date == p->nDate)
{
printf("瑕佹煡镓剧殑鍊%d鍦ㄩ摼琛ㄤ腑绗%d涓浣岖疆\r\n", date, n);
}
return;
}
//鎸夊簭鍙锋煡镓
void research_Number(Node *head, int Num)
{
Node *p=head;
int i = 0;
while(NULL != p && i < Num)
{
p = p->pstnext;
i++;
}
if(p == NULL)
{
printf("镆ユ垒浣岖疆涓嶅悎娉\r\n");
}else if(i == 0)
{
printf("镆ユ垒浣岖疆涓哄ご缁撶偣\r\n");
}else if(i == Num)
{
printf("绗%d涓浣岖疆鏁版嵁涓%d\r\n", i, p->nDate);
}
}
//鍦ㄦ寚瀹氩厓绱犱箣鍓嶆彃鍏ユ柊缁撶偣
void insert_1(Node *head, int i, int Newdate)
{
Node *pre = head, *New = NULL;
int j = 0;
while(NULL != pre && j < i-1)
{
pre = pre->pstnext;
j++;
}
if(NULL == pre || j > i-1)
{
printf("鎻掑叆浣岖疆涓嶅瓨鍦\r\n");
}else
{
New = (Node*)malloc(sizeof(Node));
if(NULL == New)
{
printf("鍒嗛厤鍐呭瓨澶辫触\r\n");
return;
}
New->nDate = Newdate;
New->pstnext = pre->pstnext;
pre->pstnext = New;
}

}
//鍦ㄦ寚瀹氩厓绱犱箣钖庢彃鍏ユ柊缁撶偣
void insert_2(Node *head, int i, int Newdate)
{
Node *pre = head, *New = NULL;
int j = 0;
while(NULL != pre->pstnext && j < i)
{
pre = pre->pstnext;
j++;
}
if(j == i)
{
New = (Node*)malloc(sizeof(Node));
if(NULL == New)
{
printf("鍒嗛厤鍐呭瓨澶辫触\r\n");
return;
}
New->nDate = Newdate;
New->pstnext = pre->pstnext;
pre->pstnext = New;
}else
{
printf("鎻掑叆浣岖疆涓嶅瓨鍦\r\n");
}
}
//鍒犻櫎鎸囧畾缁撶偣
void Delete_1(Node *head, int i3)
{
Node *p = head, *pre = NULL;
int j = 0;
while(NULL != p && j < i3)
{
pre = p;
p = p->pstnext;
j++;
}
if(NULL == p)
{
printf("鍒犻櫎浣岖疆涓嶅瓨鍦\r\n");
}else
{
pre->pstnext = p->pstnext;
free(p);
}
}
//鎸囧畾鍒犻櫎鍗曢摼琛ㄤ腑镆愪釜鏁版嵁锛屽苟缁熻″垹闄ゆゆ暟鎹镄勪釜鏁
int Delete_2(Node *head, int Delete_date)
{
int count = 0;
Node *p = head, *q;
while(NULL != p->pstnext)
{
q = p->pstnext;
if(q->nDate == Delete_date)
{
p->pstnext = q->pstnext;
free(q);
++count;
}
else
{
p = q;
}
}
return count;
}
//阈捐〃阃嗙疆
void Reverse_list(Node *head)
{
Node *q, *s;
if(NULL == head->pstnext || NULL == head->pstnext->pstnext)
{
return;
}
q = head->pstnext->pstnext;
head->pstnext->pstnext = NULL;
while(NULL != q)
{
s = q->pstnext;
q->pstnext = head->pstnext;
head->pstnext = q;
q = s;
}
}
//鍗曢摼琛ㄧ殑杩炴帴
void connect_list(Node *head, Node *head_New)
{
Node *p = head;
while(NULL != p->pstnext)
{
p = p->pstnext;
}
p->pstnext = head_New->pstnext;
}
//鍗曢摼琛ㄩ攒姣
void destroy_list(Node* head)
{
while (NULL != head)
{
Node* temp = head;
head = head->pstnext;
free(temp);
}
}
void main()
{
int date, num; //寰呮煡镓炬暟鎹
int i3; //鎸囧畾鍒犻櫎鍏幂礌镄勪綅缃
int i1, i2, Newdate_1, Newdate_2; //寰呮彃鍏ョ殑鏂版暟鎹
int Delete_date, k; //寰呭垹闄ょ殑鏁版嵁涓庡叾涓鏁
Node *Head = NULL; //瀹氢箟澶寸粨镣
Node *Head_New = NULL;

//阈捐〃寤虹珛
Head = creat();
printf("杈揿嚭寤虹珛镄勫崟阈捐〃\r\n");
output(Head);

//鍗曢摼琛ㄦ祴闀
printf("鍗曢摼琛ㄩ暱搴︿负\r\n");
length(Head);

//阈捐〃鎸夊兼煡镓
printf("璇疯緭鍏ュ緟镆ユ垒镄勬暟鎹\r\n");
scanf("%d", &date);
research_Date(Head, date);

//阈捐〃鎸夊簭鍙锋煡镓
printf("璇疯緭鍏ュ緟镆ユ垒搴忓彿\r\n");
scanf("%d", &num);
research_Number(Head, num);

//鍦ㄦ寚瀹氱琲1涓鍏幂礌涔嫔墠鎻掑叆鏂板厓绱灿ewdate
printf("鍦ㄦ寚瀹氱琲涓鍏幂礌涔嫔墠鎻掑叆鏂板厓绱灿ewdate");
printf("璇疯緭鍏i涓庡厓绱犱笖浠ラ楀彿闂撮殧\r\n");
scanf("%d,%d", &i1, &Newdate_1);
insert_1(Head, i1, Newdate_1);
printf("鎻掑叆钖庢柊阈捐〃\r\n");
output(Head);

//鍦ㄦ寚瀹氱琲2涓鍏幂礌涔嫔悗鎻掑叆鏂板厓绱灿ewdate
printf("鍦ㄦ寚瀹氱琲涓鍏幂礌涔嫔悗鎻掑叆鏂板厓绱灿ewdate");
printf("璇疯緭鍏i涓庡厓绱犱笖浠ラ楀彿闂撮殧\r\n");
scanf("%d,%d", &i2, &Newdate_2);
insert_2(Head, i2, Newdate_2);
printf("鎻掑叆钖庢柊阈捐〃\r\n");
output(Head);

//鎸囧畾鍒犻櫎i3鍏幂礌
printf("鍒犻櫎鍏幂礌镄勪綅缃\r\n");
scanf("%d", &i3);
Delete_1(Head, i3);
printf("鍒犻櫎钖庢柊阈捐〃\r\n");
output(Head);

//鎸囧畾鍒犻櫎鍗曢摼琛ㄤ腑镆愪釜鏁版嵁锛屽苟缁熻″垹闄ゆゆ暟鎹镄勪釜鏁
printf("璇疯緭鍏ュ緟鍒犻櫎镄勫厓绱\r\n");
scanf("%d", &Delete_date);
k = Delete_2(Head, Delete_date);
printf("鍒犻櫎钖庢柊阈捐〃\r\n");
output(Head);
printf("鍒犻櫎鎸囧畾鍏幂礌鍦ㄩ摼琛ㄤ腑镄勪釜鏁颁负锛");
printf("%d\r\n", k);

//鍗曢摼琛ㄩ嗙疆
Reverse_list(Head);
printf("阃嗙疆钖庤緭鍑\r\n");
output(Head);

//鍗曢摼琛ㄧ殑杩炴帴
printf("寤虹珛涓涓鏂伴摼琛\r\n");
Head_New = creat();
printf("杈揿嚭鏂伴摼琛");
output(Head);
printf("灏嗘柊阈捐〃杩炴帴鍒板师𨱒ラ摼琛ㄧ殑灏鹃儴骞惰緭鍑\r\n");
connect_list(Head, Head_New);
output(Head);
destroy_list(Head);

return;
}

㈤ 鏁版嵁缁撴瀯C璇瑷鐢ㄦ爤瀹炵幇琛ㄨ揪寮忚$畻鍣锛屾眰瀹屾暣婧愪唬镰侊纴闾绠[email protected]

#include<iostream>#include<sstream>#include<stack>#include<string>usingnamespacestd;floatstringToNum(conststring&str){istringstreamiss(str);floatnum;iss>>num;returnnum;}

intIn(stringc){if(c=="+"||c=="-"||c=="*"||c=="/"||c=="("||c==")"||c=="#")return1;elsereturn0;}

stringprocede(stringop1,stringop2){if(op1=="+"&&(op2=="*"||op2=="/"||op2=="("))return"<";if(op1=="+"&&(op2=="+"||op2=="-"||op2==")"||op2=="#"))return">";if(op1=="-"&&(op2=="*"||op2=="/"||op2=="("))return"<";if(op1=="-"&&(op2=="+"||op2=="-"||op2==")"||op2=="#"))return">";if(op1=="*"&&op2=="(")return"<";if(op1=="*"&&(op2=="+"||op2=="-"||op2=="*"||op2=="/"||op2==")"||op2=="#"))return">";if(op1=="/"&&op2=="(")return"<";if(op1=="/"&&(op2=="+"||op2=="-"||op2=="*"||op2=="/"||op2==")"||op2=="#"))return">";if(op1=="("&&op2==")")return"=";if(op1=="("&&(op2=="+"||op2=="-"||op2=="*"||op2=="/"||op2=="("))return"<";if(op1==")"&&(op2=="+"||op2=="-"||op2=="*"||op2=="/"||op2==")"||op2=="#"))return">";if(op1=="#"&&(op2=="+"||op2=="-"||op2=="*"||op2=="/"||op2=="("||op2=="#"))return"<";}

floatoperate(floata,stringop,floatb){if(op=="+")returna+b;if(op=="-")returna-b;if(op=="*")returna*b;if(op=="/")returna/b;}

intevaluateExpression(){floatnum1,num2;stack<float>OPND;//瀛樻斁杩愮畻鏁stack<string>OPTR;//瀛樻斁镎崭綔绗OPND.empty();OPTR.empty();OPTR.push("#");std::stringc;cin>>c;while(c!="#"||OPTR.top()!="#"){if(!In(c))//涓嶆槸杩愮畻绗﹁繘镙{OPND.push(stringToNum(c));cin>>c;}else{//cout<<procede(OPTR.top(),c)<<endl;if(procede(OPTR.top(),c)=="<"){OPTR.push(c);cin>>c;}elseif(procede(OPTR.top(),c)=="="){OPTR.pop();cin>>c;}elseif(procede(OPTR.top(),c)==">"){stringop=OPTR.top();OPTR.pop();num1=OPND.top();OPND.pop();num2=OPND.top();OPND.pop();

OPND.push(operate(num2,op,num1));}}}if(!OPND.empty())returnOPND.top();elsereturn0;}

intmain(){while(1){cout<<evaluateExpression()<<endl;}system("pause");return0;}

热点内容
停车场管理系统c语言 发布:2025-01-16 09:02:35 浏览:437
学校宣传片拍摄脚本 发布:2025-01-16 09:00:50 浏览:155
ubuntuphpmcrypt 发布:2025-01-16 08:26:46 浏览:429
安卓图片如何添加苹果的水墨印 发布:2025-01-16 08:18:12 浏览:731
fmp脚本 发布:2025-01-16 08:12:23 浏览:231
nagios自定义脚本 发布:2025-01-16 08:09:52 浏览:365
安卓为什么下不了方舟生存进化 发布:2025-01-16 08:02:32 浏览:194
如何登录男朋友的微信密码 发布:2025-01-16 07:41:14 浏览:194
宝骏解压流程 发布:2025-01-16 07:35:35 浏览:2
两匹压缩机多少钱 发布:2025-01-16 07:29:19 浏览:635