版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
1、关注非咸鱼获取干货福利1输入整型数组求数组的最小数和最大数之和,例如输入 1,2,3,4 则输出为 5,当输入只有一个数的时候,则最小数和最大数都是该数,例如只输入 1,则输出为 2;另外数组的长度不超过 50参考代码:#includemain()num50=0;i,n;prf(“请输入整型数组的长度(150):”);scanf(“%d”,&n);prf(“请输入整型数组的元素:”);for (i=0;in;i+)scanf(“%d”,&numi);min_num=num0;max_num=num0;for(j=0;jn;j+)if(max_numnumj)min_num=numj;sum=m
2、in_num+max_num;prf(“数组中最大与最小值之和:%dn”,sum);return 0;2求两个长长整型的数据的和并输出,例如输入 12333333333333331111111.。,则输出。#include#include#includemain()char *num1,*num2; /两个长长整型数据char *sum;/temp;len_num1,len_num2; / 两个长长整型数据的长度len_max,len_min;num1=(char*)malloc(sizeof(char);num2=(char*)malloc(sizeof(char);prf(“输入两个长长整
3、型数据:”);scanf(“%s”,num1);prf(“输入两个长长整型数据:”);scanf(“%s”,num2);len_num1=strlen(num1);len_num2=strlen(num2);len_max=(len_num1=len_num2)? len_num1:len_num2;len_min=(len_num10&len_num20;len_num1,len_num2)sumlen_max-=(num1len_num1-1-0)+(num2len_num2-1-0);if(len_num10)sumlen_max-=num1len_num1- 1 -0;len_num1
4、;if(len_num20)sumlen_max-=num1len_num2- 1-0;len_num2;for(j=len_max1;j=0;j)/实现进位操作/temp=sumj-0;if(sumj=10)sumj-1+=sumj/10;sumj%=10;char*outsum=(char*)malloc(sizeof(char)*len_max1);j=0;while(sumj=0) /跳出头部 0 元素j+;for(m=0;mlen_max1;j+,m+)outsumm=sumj+0;outsumm=0;prf(“输出两长长整型数据之和:%sn”,outsum);return 0;3.
5、通过键盘输入一串小写字母(az)组成的字符串。请编写一个字符串过滤程序,若字符串中出现多个相同的字符,将非首次出现的字符过滤掉。比如字符串”abacacde”过滤结果为”abcde”。要求实现函数:voidstringFilter(constchar*pInputStr,longlInputLen,char*pOutputStr);【输入】 pInputStr:输入字符串lInputLen:输入字符串长度【输出】 pOutputStr:输出字符串,空间已经开辟好,与输入字符串等长;参考代码:#include #include#includevoid stringFilter(const cha
6、r*p_str,longlen,char*p_outstr)array256=0;constchar *tmp = p_str;for(j=0;jlen;j+)if(arraytmpj=0)*p_outstr+=tmpj;arraytmpj+;*p_outstr= 0;voidmain()char *str= “cccddecc”;len =strlen(str);char * outstr = (char*)malloc(len*sizeof(char);stringFilter(str,len,outstr);prf(“%sn”,outstr);free(outstr);outstr =
7、NULL;5.通过键盘输入 100 以内正整数的加、减运算式,请编写一个程序输出运算结果补充说明:1. 操作数为正整数,不需要考虑计算结果溢出的情况。2. 若输入算式格式错误,输出结果为”0。要求实现函数:voidarithmetic(constchar*pInputStr,longlInputLen,char*pOutputStr);【输入】 pInputStr: 输入字符串lInputLen: 输入字符串长度【输出】 pOutputStr: 输出字符串,空间已经开辟好,与输入字符串等长;#include #include#includevoid arithmetic(const char
8、*input, long len, char *output)字符串。输入字符串的格式为:”操作数 1 运算符 操作数 2,”操作数”与”运算符”之间以一个空格隔开。chars110;chars210;chars310;cnt = 0;len_input=strlen(input);for(i=0;ilen_input;+i)if(inputi= )cnt+;if(cnt!=2)*output+= 0;*output =0;return;sscanf(input,”%s%s %s”,s1,s2,s3);if(strlen(s2)!=1|(s20!=+&s20!=-)*output+ = 0;*
9、output = 0;return;len_s1=strlen(s1);for(i=0;ilen_s1;i+)if(s1i9)*output+ = 0;*output = 0;return;len_s3=strlen(s3);for(i=0;ilen_s3;i+)if(s3i9)*output+= 0;*output=0;return;x = atoi(s1);y = atoi(s3);if(s20=+)result = x+y;itoa(result,output,10);elseif(s20=-)result = x-y;itoa(result,output,10);else*output
10、+= 0;*output =0;return;voidmain()charstr = “10 23;charoutstr10;len = strlen(str);arithmetic(str,len,outstr);prf(“%sn”,str);prf(“%sn”,outstr);6.一组人(n 个),围成一圈,从开始数到第三个的人出列,再接着从下一个人开始数,最终输出最终出列的人(环是一个数学的应用问题:已知 n 个人(以1,2,3n 分别表示)围坐在一张圆桌周围。从为k 的人开始报数,数到 m 的那个人出列;他的下一个人又从 1 开始报数,数到 m 的那个人又出列;依此规律重复下去,直到圆
11、桌周围的人全部出列。)#include #include#include#includetypedef struct Nodedata;struct Node*next;LinkList;LinkList *create(n)LinkList *p,*q,*head;i=1;p=(LinkList*)malloc(sizeof(LinkList);p-data=i;he;for(i=1;idata=i+1;p-next=q;p=q;p-next=head;/使链表尾连接链表头,形成循环链表return head;free(p);p=NULL;free(q);q=NULL;void delete
12、fun(LinkList*L,m)LinkList *p,*q,*temp;i;p=L;while(p-next!=p)for(i=1;inext;prf(“%5d”,p-data);temp=p;q-next=p-next;p=p-next;free(temp);prf(“%5dn”,p-data);main()n=7,m=3;LinkList *head1;head1=create(n);deletefun(head1,m);return 0;7.输入一串字符,只包含”0-10和”,”找出其中最小的数字和最大的数字(可能不止一个),输出最后剩余数字个数。如输入“3,3,4,5,6,7,7#
13、include#include#includevoidmain()char str100;prf(“输入一组字符串:n”);scanf(“%s”,&str);len=strlen(str);array100;count=0;for(i=0;i=0&stri=9)arraycount+=stri-0;arraycount=0;result=count;min=array0;max=array0;for(j=0;jcount;j+)if(maxarrayj)min=arrayj;for(k=0;kcount;k+)if(arrayk=min)result;if(arrayk=max)result;
14、prf(“%dn”,result);8.输入一组身高在 170 到 190 之间(5 个身高),比较身高差,选出身高差最小的两个身高;若身高差相同,选平均身高高的那两个身高;从小到大输出;如输入 170 181 173 186190 输出170173#include#include#define N 5main()HeightN;dmin;H1,H2;i,j,temp;prf(“请输入一组身高在 170 到 190 之间的数据(共 5 个):n”);for(k=0;kN;k+)scanf(“%d”,&Heightk);prf(“n”);for(i=0;iN;i+)for(j=1;jHeight
15、j;j+)temp=Heightj-1;Heightj-1=Heightj;Heightj=temp;H1=Height0;H2=Height1;dmin=H2-H1;for(m=2;mN;m+)if(Heightm-Heightm-1=dmin)H1=Heightm-1;H2=Heightm;dmin=Heightm-Heightm-1;prf(“身高差最小的两个身高为:n”);prf(“%d,%dn”,H1,H2);return 0;9.删除子串,只要是原串中有相同的子串就删掉,不管有多少个,返回子串个数。#include#include#include#includedelete_sub
16、_str(const char*str,constchar *sub_str,char*result)assert(str != NULL &sub_str!=NULL);const char *p,*q;char *t,*temp;p=str;q=sub_str;t=result;n,count = 0;n=strlen(q);temp = (char *)malloc(n+1);memset(temp,000,n+1);while(*p)memcpy(temp,p,n);if(strcmp(temp,q) =0 )count+;memset(temp,000,n+1);p = p + n;
17、else*t = *p;p+;t+;memset(temp,000,n+1);free(temp);return count;void main()char s100 =0;num = delete_sub_str(“123abc12de234fg1hi34j123k”,”123,s);prf(“The number of sub_str is %drn”,num);prf(“The result string is %srn”,s);10. 要求编程实现上述高精度的十进制加法。要求实现函数:void add (const char *num1, const char *num2, char
18、*result)【输入】num1:字符串形式操作数 1,如果操作数为负,则 num10为符号位-num2:字符串形式操作数 2,如果操作数为负,则 num20为符号位-【输出】result:保存加法计算结果字符串,如果结果为负,则 result0为符号位。#include#include#includevoid move(char *str,length) /移除字母前的”-”符号if(str0 != -)return;i;for(i = 0; i 0; i) /从最后开始移除 0,直到遇到非 0 数字,只对最初位置上的 0 不予判断if(resulti = 0)resulti = 0;cou
19、nt+;elsereturn length-count;return length count;voidreverse(char *result,length) /将字符串倒转chartemp;for(i = 0; i = 0 & j= 0; i,j)n1 = str1i 0;n2 = str2j 0;curSum = n1 + n2+another;resultcur_rs+=curSum % 10 + 0;another = curSum/10;if(j = 0) /遍历 str1 剩余各位n1 = str1i- 0;curSum = n1 + another;resultcur_rs+=
20、 curSum % 10 + 0;another = curSum/ 10;if(another != 0)/如果还有进位未加上resultcur_rs+= another + 0;elsewhile(j = 0)n2 = str2j- 0;curSum = n2 + another;resultcur_rs+ = curSum % 10 + 0;another = curSum / 10;if(another != 0)resultcur_rs+ = another +0;resultcur_rs = 0;cur_rs = remove_zero(result,cur_rs);if(!fla
21、g)resultcur_rs+ = -;resultcur_rs = 0;reverse(result, strlen(result);return cur_rs;real_minus(char *str1, char *str2,char *result) /使用 str1 减去str2char big100, small100;big_len, sml_len;len1 = strlen(str1);len2 = strlen(str2);bool flag = false; /用于标记 str2 是否比 str1 大if(len1 len2)flag = true;else if(len
22、1 = len2)if(strcmp(str1, str2) = 0)result0 = 0;result1 = 0;return 1;else if(strcmp(str1,str2) =0 & j=0; i,j)n1 = str1i 0;n2 = str2j 0;if(n1 = n2+another)resultcur_rs+ = (n1-n2-another) +0;another = 0;elseresultcur_rs+= (n1+10-n2-another)+0;another = 1;while(i = 0)n1 = str1i- 0;if(another != 0)n1 -=
23、another;another = 0;resultcur_rs+= n1 + 0;resultcur_rs =0;cur_rs = remove_zero(result, cur_rs);if(flag)resultcur_rs+ = -;resultcur_rs = 0;reverse(result, cur_rs);return cur_rs;void addi(const char *num1,constchar*num2,char*result)len1 = strlen(num1);len2 = strlen(num2);rs_len;if(!len1 | !len2)return
24、;char str1100, str2100;strncpy(str1, num1, len1);str1len1 = 0;strncpy(str2, num2, len2);str2len2 = 0;if(str10= - & str20 = -)move(str1,len1);move(str2,len2);rs_len = real_add(str1, str2, result, false);else if(str10 = -)move(str1, len1);rs_len = real_minus(str2, str1,result);else if(str20 = -)move(s
25、tr2, len2);rs_len = real_minus(str1, str2,result);elsers_len = real_add(str1, str2, result, true);/main(argc, char *argv)main()char num1100,num2100;prf(“请输入两个整型数据:n”);scanf(“%s%s”,num1,num2);char result100;memset(result, 0, 100);addi(num1,num2, result);prf(“%sn”, result);return 0;11.描述:10 个学生考完期末下:评
26、卷完成后,A 老师需要划出及格线,要求如(1)(2)(3)及格线是 10 的倍数;保证至少有 60%的学生及格;如果所有的学生都高于 60 分,则及格线为 60 分输入:输入 10 个整数,取值 0100输出:输出及格线,10 的倍数#includevoid bubblesort(arr)i,j,temp;for(i=0;i10;i+)for(j=0;jarrj+1;j+)temp=arrj;arrj=arrj+1;arrj+1=temp;GetPassLine(a)bubblesort(a);if(a0=60)return 60;elsereturn ()a4/10)*10);main()a
27、10=0;result;prf(“请随机输入 10 个成绩(0-100):n”);scanf(“%d%d%d%d%d%d%d%d%d%d”,&a0,&a1,&a2,&a3,&a4,&a5,&a6,&a7,&a8,&a9);prf(“n”);result=GetPassLine(a);prf(“及格线为:%dn”,result);return 1;12.描述:一条长廊里依次装有 n(1 n 65535)盏电灯,从头到尾2、3、n-1、n。每盏电灯由一个拉线开关控制。开始,电灯全部关着。1、有 n 个学生从长廊穿过。第一个学生把号码凡是 1 的倍数的电灯的开关拉一下;接着第二个学生把号码凡是 2
28、的倍数的电灯的开关拉一下;接着第三个学生把号码凡是 3 的倍数的电灯的开关拉一下;如此继续下去,最后第 n 个学生把号码凡是 n 的倍数的电灯的开关拉一下。n 个学生按此规定走完后,长廊里电灯有几盏亮着。注:电灯数和学生数一致。输入:电灯的数量输出:亮着的电灯数量样例输入:3样例输出:1#include#define Max_Bubl_Num 65535GetLightLampNum(n)BublNumMax_Bubl_Num=0; /0 表示灯灭,1 表示灯亮unsignedi,j;unsignedcount=0;for(i=1;i=n;i+)for(j=i;j=n&j%i=0;j+)Bub
29、lNumj-1+=1;BublNumj-1=BublNumj-1%2;for(k=0;kn;k+)if(BublNumk=1)count+;return count;main()n,result;prf(“请输入灯的数量(1-65535):n”);scanf(“%d”,&n);result=GetLightLampNum(n);prf(“最后亮灯的数量为:%dn”,result);return 0;13.描述:已知 2 条地铁线路,其中 A 为环线,B 为东西向线路,线路都是双向的。经过的站点名分别如下,两条线交叉的换乘点用 T1、T2 表示。编写程序,任意输入两个站点名称,输出乘坐地铁最少需
30、要经过的车站数量(含输入的起点和终点,换乘站点只计算一次)。地铁线 A(环线)经过车站:A1 A2 A3 A4 A5 A6 A7 A8 A9 T1 A10 A11 A12 T2 A14 A15 A16 A17 A18地铁线 B(直线)经过车站:B1 B2 B3 B4 B5 T1 B6 B7 B8 B9 B10 T2 B11B13 B14 B15A13B12输入:输入两个不同的站名输出:输出最少经过的站数,含输入的起点和终点,换乘站点只计算一次输入样例:A1 A3输出样例:3#include#include#include#includeusing namespatd;#defineMAX 35
31、#defineSUBWAY_A20#defineSUBWAY_B15typedefstruct nodeadjvex;struct node *next;edgenode;typedef structchar name10;bool flag;edgenode *link;vexnode;const char subway_name1SUBWAY_A10=“A1,”A2,”A3,”A4,” A5,”A6,”A7,”A8,”A9,”T1,”A10,”A11,”A12,”A13,”T2,”A14,”A15,”A16,”A17,”A18;const char subway_name2SUBWAY_B
32、10=“B1,”B2,”B3,”B4,” B5,”B6,”B7,”B8,”B9,”B10,”B11,”B12,”B13,”B14,”B15;void creat(vexnode ga)i;edgenode *p;for(i=0;iMAX;i+)gai.link=NULL;gai.flag=true;if(iSUBWAY_A) strcpy(,subway_name1i);else strcpy(,subway_name2i-20);/A 地铁建邻接表for(i=1;iadjvex=i-1;p-next=NULL;gai.link=p;p=(edgenode*)m
33、alloc(sizeof(edgenode);p-adjvex=i+1;p-next=NULL;gai.link-next=p;if(i=9)p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+4;p-next=NULL;gai.link-next-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+5;p-next=NULL;gai.link-next-next-next=p;else if(i=14)p=(edgenode*)malloc(sizeof(edge
34、node);p-adjvex=SUBWAY_A+9;p-next=NULL;gai.link-next-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+10;p-next=NULL;gai.link-next-next-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A-1;p-next=NULL;ga0.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=1;p-next=NULL;ga0.l
35、ink-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A-2;p-next=NULL;gaSUBWAY_A-1.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=0;p-next=NULL;gaSUBWAY_A-1.link-next=p;/B 地铁建邻接表for(i=1;iadjvex=SUBWAY_A+i-1;p-next=NULL;gai+SUBWAY_A.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex
36、=SUBWAY_A+i+1;p-next=NULL;gai+SUBWAY_A.link-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+3;p-next=NULL;gaSUBWAY_A+4.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=9;p-next=NULL;gaSUBWAY_A+4.link-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=9;p-next=NULL;gaSUBWAY_A+5.li
37、nk=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+6;p-next=NULL;gaSUBWAY_A+5.link-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+8;p-next=NULL;gaSUBWAY_A+9.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=14;p-next=NULL;gaSUBWAY_A+9.link-next=p;p=(edgenode*)malloc(sizeof
38、(edgenode);p-adjvex=14;p-next=NULL;gaSUBWAY_A+10.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+11;p-next=NULL;gaSUBWAY_A+10.link-next=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+1;p-next=NULL;gaSUBWAY_A.link=p;p=(edgenode*)malloc(sizeof(edgenode);p-adjvex=SUBWAY_A+SUBWAY
39、_B-2;p-next=NULL;gaSUBWAY_A+SUBWAY_B-1.link=p;/ 打印各邻接节点for(i=0;i%s”,);s=s-next;prf(“n”);main()vexnode gaMAX;creat(ga);i;char str210;while(scanf(“%s%s”,str0,str1)!=EOF)temp=0;for(i=0;iMAX;i+)gai.flag=true;if(!strcmp(str0,)temp=i;queueq;q.push(gatemp);gatemp.flag=false;count=0;s
40、tart=0;end=1;bool find_flag=false;while(!q.empty()if(find_flag) break;count+;prf(“*n”);prf(“第%d 层搜索:”,count);temp_end=end;while(startadjvex.flag)q.push(gas-adjvex);gas-adjvex.flag=false;end+;/prf(“%s “,);s=s-next;q.pop();start+;prf(“n”);prf(“%dn”,count);return 0;14.字串转换问题描述:将输入的字符串(字符
41、串仅包含小写字母a到z),按照如下规则,循环转换后输出:a-b,b-c,y-z,z-a;若输入的字符串连续出现两个字母相同时,后一个字母需要连续转换 2 次。例如:aa 转换为 bc,zz 转换为同字母超过两个时,第三个出现的字母按第一次出现算。要求实现函数:void convert(char *inphar* output)【输入】 char *input , 输入的字符串【输出】 char *output ,输出的字符串【返回】无ab;当连续相#include#include#includevoid convert(char *inphar* output)if(input=NULL)re
42、turn;char temp=0;len_input=strlen(input);i;flag=0;for(i=0;ilen_input;i+)if(inputi!=temp)outputi=(inputi-a+1)%26+a;temp=inputi;flag=1;elseif(flag=1)outputi=(inputi-a+2)%26+a;temp=inputi;flag=0;elseoutputi=(inputi-a+1)%26+a;temp=inputi;flag=1;outputi=0;voidmain()char *input=”xyz”;char output256;/scanf
43、(“%s”,input);convert(input,output);prf(“%sn”,output);15.在给定字符串中找出单词( “单词”由大写字母和小写字母字符,其他非字母字符视为单词的间隔,如空格、问号、数字等等;另外单个字母不算单词);找到单词后,按照长度进行降序排序,(排序时如果长度相同,则按出现的顺序进行排列),然后输出到一个新的字符串中;如果某个单词重复出现多次,则只输出一次;如果整个输入的字符串中没有找到单词,请输出空串。输出的单词之间使用一个”空格”隔开,最后一个单词后不加空格。要求实现函数:void my_word(charinput, char output)【输入
44、】 char input, 输入的字符串【输出】 char output,输出的字符串【返回】无#include#include#includevoidmy_word(char input,charoutput)char*p;char*temp;char*word10;len_input=strlen(input);i,j;char except = “,”;char *bl= ” “;i=0;for (i=0;ilen_input;i+)if (inputiZ&inputiz)inputi=,;j=0;/*保存取出的单词*/p= strtok(input,except);while(NULL
45、!=p)wordj+=p;p= strtok(NULL,except);for(i=0;i5;i+)prf(“%s”,wordi);/*对单词按照长度降序排序,冒泡法*/for (i=0;i5;i+)for (j=1;j5-i;j+)if(strlen(wordj-1)strlen(wordj)temp=wordj;wordj=wordj-1;wordj-1=temp;/*删除相同单词*/for (i=0;i5;i+)for(j=i+1;j5;j+)if(strcmp(wordi,wordj)=0)wordj=”0;/*将单词连接起来输出*/for (j=0;j5;j+)if (0=j)str
46、ncpy(output,wordj,strlen(wordj)+1);elsestrcat(output,bl);strcat(output,wordj);return ;main()char input =”some localbuses, some1234123drivers”;prf(“筛选之前的字符串:%sn”,input);char output30;my_word(input,output);prf(“筛选之后的字符串:%s”,output);prf(“n”);return 0;.数组中数字都两两相同,只有一个不同,找出该数字:findUnique(* a,len)i = 1;te
47、mp = a0;for(; i len; i+)temp = temp ai;prf(“%d “, temp);17.题目二:数组中数字两两相同,有两个不同,找出这两个:#include a = 1,1,2,4,3,3,2,5;findXorSum(* a,len)i = 0;temp = 0;for(; i 1;count+;return count;isBit1(a,count)a = a count-1;return (a & 1);voidfindTwoUnique(* a,len)i = 0;m = 0, n= 0;temp = findXorSum(a, len);count =
48、findBit1(temp);for(; i len; i+)if(isBit1(ai,count)m = m ai;elsen = n ai;prf(“%d, %d”, m, n);main()findTwoUnique(a,8);18.链表翻转。给出一个链表和一个数 k,比如链表 123456,k=2,则翻转后 214365,若 k=3,翻转后 321654,若 k=4,翻转后 432156,用程序实现:采用遍历链表,分成 length/k 组,对每组进行逆转,逆转的同时要将逆转后的尾和头连接起来/#include “stdafx.h”#include “stdio.h”#include
49、“stdlib.h”#includetypedef struct Nodevalue;Node* next;LinkList;void Converse(LinkList* pPre,LinkList*pCur)/链表逆转LinkList* p = NULL;LinkList* pNext = NULL;p = pPre-next;LinkList* p1 = NULL;if(pCur!=NULL)pNext = pCur-next;while(p!=pNext)p1 = p-next;p-next = pPre;pPre = p;p = p1;main()count = 0, k,i=0,j
50、=0,flag = 1,length=0,groups = 0;scanf(“%d”,&k);LinkList*pPre = (LinkList*)malloc(sizeof(LinkList);LinkList*pCur = (LinkList*)malloc(sizeof(LinkList);LinkList*pNext = (LinkList*)malloc(sizeof(LinkList);LinkList*head = NULL;LinkList* pTempTail = NULL; /指向逆转之后的尾部LinkList* pTempHead = NULL;pCur-value =
51、1;pPre = pCur; /创建初始链表for(i=2;ivalue = i;pCur-next = node;pCur = node;pCur-next = NULL;/最后一定要置 NULL,c+中用 new 则无须置 NULLpCur = pPre;while(pCur!=NULL)length+;pCur = pCur-next;i=0;groups = length/k; /分成 K 段pCur = pPre;while(i=groups)count = 0;while(countk-1 & inext;count+;if(inext;pTempHead = pCur; /*没做
52、翻转之前的头部,变成了翻转之后的尾部*/if(flag = 0)pTempTail-next=pTempHead;pTempTail = pPre;Converse(pPre,pCur);/pTempTail = pPre;if(flag=1)head = pCur;flag = 0;pCur = pNext;elsepTempTail-next =pNext;pPre = pCur;i+;pCur = head;while(jvalue);pCur = pCur-next;prf(“n”);/system(“pause”);return 0;19.链表相邻元素翻转,如 a-b-c-d-e-f
53、-g,翻转后变为:b-a-d-c-f-e-g#include#include#includetypedef struct nodechar val;struct node* pNext;Node;Node* Creaist(n);void Traverslist(Node* pHead);Node* TransNeighbor(Node* pHead);main()Node* pHead = Creaist(7);prf(“before transformn”);Traverslist(pHead);TransNeighbor(pHead);prf(“nafter transformn”);T
54、raverslist(pHead);getchar();return 1;/创建新链表Node* Creaist(n)Node* pHead= (Node*)malloc(sizeof(Node);Node* pTail= pHead;pTail-pNext=NULL;i;for(i=0; i val = a+i;pTail-pNext = pNew;pNew-pNext = NULL;pTail = pNew;return pHead;voidTraverslist(Node*pHead)Node* p =pHead-pNext;is= 0;while(p!=NULL)if(is=0)prf
55、(“%c”,p-val);is=1;elseprf(“-%c”,p-val);p = p-pNext;return;Node*TransNeighbor(Node* pHead)Node* p = pHead-pNext;while(p-pNext!=NULL & p-pNext-pNext!=NULL)char value = p-val;p-val=p-pNext-val;p-pNext-val=value;p=p-pNext-pNext;return pHead;20.输入一串字符串,其中有普通的字符与括号组成(包括(、)、,),要求验证括号是否匹配,如果匹配则输出 0、否则输出 1.#
56、include#include/#define MAX 100main()char a100,c=”(1+2)”;i=0,j=0;flag=0;while(ci!=NULL&flag=0)switch(ci)case():case():aj+=ci;break;case():if(aj-1=()aj-1=0;j;elseflag=1;break;case():if(aj-1=)aj-1=0;j;elseflag=1;break;i+;if(j!=0) flag=1;prf(“%dn”,flag);return 0;方法 2:#include#include#include / !分配内存头文件
57、#definem 20typedefchar ElemType;typedefstructElemType stackm;top;stacknode;stacknode *sp;Init(stacknode *st)st-top=0;return 0;void Push(stacknode*semType x)if(st-top=m)prf(“The stack is overflow!n”);elsest-top=st-top+1;st-stackst-top=x;void Pop(stacknode *st)st-top=st-top-1;main()char sm=”()”;i;prf(
58、“Creat a stack!n”);sp = (stacknode *)malloc(sizeof(stacknode);/!添加的语句Init(sp);prf(“Input a expres:n”);/ gets(s);for(i=0;itop=0)prf(“左右括号是匹配的!n”);elseprf(“左右括号是不匹配的!n”);return 0;将第一行中含有第二行中”23的数输出并排序2.输入一行数字:123423在输入第二行:235645875186523将第一行中含有第二行中”23的数输出并排序结果即:123423186523#include#define M 20main()aM
59、;i,j,s,temp;sortM,t=0;char c= ;i=0;while(c!=n)scanf(“%d%c”,&temp,&c);ai+=temp;scanf(“%d”,&s);for(j=0;ji;j+)temp=aj;if(temp%100=s)sortt+=aj;elsetemp/=10;for(i=0;it-1;i+)for(j=0;jsortj+1)temp=sortj+1;sortj+1=sortj;sortj=temp;for(i=0;it;i+)prf(“%d“,sorti);prf(“n”);return 0;的位数用 0 补齐。如 n=8m=9 ,123456789
60、 划分为:1234567890000000123 化为:12300000#include#include输入m 个字符串 和一个整数 n, 把字符串M 化成以 N 为的段,不足main()char c200=0;scanf(“%s”,&c);n,i,j;len=strlen(c);scanf(“%d”,&n);for(i=1;i=len;i+)j=i%n;prf(“%c”,ci-1);if(j=0)prf(“n”);if(j!=0)for(i=j+1;i=n;i+)prf(“0);return 0;将翻译成 1号码onetwo。ninezero2。90中间会有 double例如输入:OneTw
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2024年度水库工程承建商协议模板
- 2024外汇资金借款协议参考样式
- 2024年装修住宅维护服务协议
- 2024年出口商品协议格式
- 二手房买卖2024中介服务协议样本
- 2024年度污水站运维专业服务协议
- 2024年度企业专属物流配送服务协议
- 2024年项目转让居间协议格式
- 2024工程领域劳务中介协议模板
- 2024年个人消费融资协议样式
- 跌倒坠床的护理文献
- 仙庾岭风景区游憩价值评价的开题报告
- 北京市大兴区2023-2024学年七年级上学期期中考试英语试题
- (南京专版)江苏省南京市2023-2024学年三年级数学上册期中综合素养测评调研试卷(苏教版)
- 2022-2023学年北京西城区北师大附初二期中(上)物理试卷及答案
- 西泠版五年级书法上册《第10课 山字头与京字头》教学设计
- 2022年湖南省衡南县五科联赛数学试卷
- 布氏硬度对照表
- 小学数学解题研究全套教学课件
- 精算模型真题模拟汇编(共704题)
- 大学生创新创业PPT完整全套教学课件
评论
0/150
提交评论