1 •第一题的题目大概是输入整型数组求数组的最小数和最大数之和,例如输入1,2,3,4则输出为5,当输入只有一个数的时候,则最小数和最大数都是该数,例如只输入1,则输出为2;另外数组的长度不超过50#i nclude<stdio.h>mai n(){intn um[50]={0};in ti, n;printf("请输入整型数组的长度(1~50):");scan f("%d",&n);printf("请输入整型数组的元素:");for(i=0;i <n ;i++){sca nf("%d",&n um[i]);}intmin_num=num [0];in tmax_ num=nu m[0];for(i ntj=0;j< n;j++){if(max_ numvnu m[j])max_num=nu m[j];elseif(min_ num>nu m[j])min_num=nu m[j];}in tsum=min_nu m+max_ num;printf("数组中最大与最小值之和:%d\n",sum);return。
;}2. 求两个长长整型的数据的和并输出,例如输入1233333333333333.OO3111111111111111111111111。
O,则输出。
OOO#i nclude<stdio.h>#i ncludevstri ng.h>#i nclude<malloc.h>mai n(){char* nu ml,* num2; //两个长长整型数据char*sum;// in ttemp;int Ien_num1,len_num2; //两个长长整型数据的长度in tle n_ max,le n_min;nu m1=(char*)malloc(sizeof(char));nu m2=(char*)malloc(sizeof(char));printf("输入两个长长整型数据:");scan f("%s", nu m1);printf("输入两个长长整型数据:");scan f("%s", nu m2);len_nu m仁strle n(nu m1);len_nu m2=strle n(nu m2);len_ max=(le n_nu m1>=le n_nu m2)?le n_nu m1:le n_nu m2;len_ mi n=(le n_nu m1<=le n_nu m2)?le n_nu m1:le n_nu m2;int len _max1=le n_max;sum=(char*)malloc(sizeof(char)*le n_max);memset(sum,OxOO,len_max+1);〃切忌初始化for(;le n_nu m1> 0&&le n_nu m2>0;le n_nu m1--,le n_nu m2--){sum[len_max--]=(( nu m1[len_num1-1]-'0')+( nu m2[len_num2-1]-'0'));}if(len_num1>0){sum[le n_max--]=nu m1[le n_nu m1- 1 ]-'0';len_nu m1--;}if(len_num2>0){sum[le n_max--]=nu m1[le n_nu m2- 1]-'0';len_nu m2--;}for(intj=len_max1;j>=0;j--) // 实现进位操作{// temp=sum[j]-'0';if(sum[j]>=10){sum[j-1]+=sum[j]/10;sum[j]%=10;}}char*outsum=(char*)malloc(sizeof(char)*le n_ maxi);j=0;while(sum[j]==0) // 跳出头部0 元素j++;for(i nt m=0;m<le n_max1;j++,m++)outsum[m]=sum[j]+'0';outsum[m]='\0';printf("输出两长长整型数据之和:%s\n",outsum);return。
;}#i nclude <stdio.h>#i nclude<stri ng.h>#i nclude<malloc.h>void stri ngFilter(c onst char *p_str, l on gle n, char *p_outstr){in tarray[256]={0};const char *tmp = p_str;for(i nt j=O;j<le n;j++){if(array[tmp[j]]==O)*p_outst r++=tmp[j];array[tmp[j]]++;}*p_outstr= '\0';}void mai n(){char *str = "cccddecc";in tle n = strle n(str);char* outstr = (char *)malloc(le n*sizeof(char));stri ngFilter(str,le n, outstr);prin tf("%s\n",outstr);free(outstr);outstr= NULL;}#i nclude <stdio.h>#i nclude<stri ng.h>#i nclude<malloc.h>void stri ngZip(c onst char *p_str, l ong len, char *p_outstr) { in tco un t=1;for(i nti=0;i<le n;i++){if(P_str[i]==p_str[i+1]){coun t++;}else{if(cou nt>1){*p_outstr++= count +'0';*p_outst ^+=p_str[i];}else{*p_outst ^+=p_str[i];}cou nt = 1;//注意其位置}}*p_outstr= '\0';}void mai n(){char*str = "cccddecc";prin tf("压缩之前的字符串为: %s\n",str);in tle n = strle n(str);char* outstr = (char*)malloc(le n*sizeof(char));stri ngZip(str,le n, outstr);printf("压缩之后的字符串为:%s\n",outstr);free(outstr);outstr= NULL;#i nclude <stdio.h>#i nclude<stri ng.h>#i nclude<stdlib.h>void arithmetic(c onst char *in put, l on gle n, char *output) {chars1[10];chars2[10];chars3[10];intent = 0;in tle n_in put=strle n(i nput);for(i nti=0;i<le n_in put;++i){if(in put[i]=='')cn t++;}if(cnt!=2){*output++= 'O';*output= '\O';return;}sscanf(input,"%s %s %s",s1,s2,s3);if(strlen(s2)!=1| |(s2[0]!='+'&&s2[0]!='-')) { *output++= '0';*output= '\0'; return;}int len _s1=strle n( s1);for(i=0;i<le n_s1;i++){if(s1[i]v'0'||s1[i]>'9'){*output++= '0';*output= '\0';return;}}in tle n_s3=strle n( s3);for(i=0;i<le n_s3;i++){if(s3[i]v'0'||s3[i]>'9'){*output++= '0';*output= '\0';return;int x = atoi(sl);int y = atoi(s3); if(s2[0]=='+') {in tresult = x+y; itoa(result,output,10); }elseif(s2[0]=='-'){in tresult = x-y; itoa(result,output,10);}else{*output++= '0'; *output= '\0'; return;} }void mai n(){charstr[] = {"10 - 23"}; charoutstr[10];in tle n = strle n(str); arithmetic(str,le n, outstr); prin tf("%s\n",str);prin tf("%s\n",outstr);6. —组人(n个),围成一圈,从某人开始数到第三个的人出列,再接着从下一个人开始数,最终输出最终出列的人(约瑟夫环是一个数学的应用问题:已知n个人(以编号1,2, 3...n分别表示)围坐在一张圆桌周围。
从编号为k的人开始报数,数到m的那个人出列;他的下一个人又从1开始报数,数到m的那个人又出列;依此规律重复下去,直到圆桌周围的人全部出列。