C语言上机必背10道题.docx

  1. 1、本文档共3页,可阅读全部内容。
  2. 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
  3. 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  4. 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多

C语言上机必备10道题

1、个十百千位加减并大小排序问题:

求出个位数上的数减千位数上的数减百位数上的数减十位数上的数大于零的个数cnt,再把所有满足此条件的四位数依次存入数组b中,然后对数组b的四位数按从大到小的顺序进行排序。

{

inti,j,k,t;

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

if(a%10-a/1000-a/100%10-a/10%100)

b[cnt++]=a;

for(i=0;icnt-1;i++)

{k=i;

for(j=i+1;jcnt;j++)if(b[k]b[j])k=j;

if(k!=i){t=b[k];b[k]=b;b=t;}

} }

2、个十百千重新排列,符合条件的数大小排序问题:

把千位数字和十位数字重新组成一个新的十位数ab(新十位数的十位数字是原四位数的千位数字,新十位数的个位数字是原四位数的十位数字),以及把个位数字和百位数字组成另一个新的十位数cd(新十位数的十位数字是原四位数的个位数字,新十位数的个位数字是原四位数的百位数字),如果新组成的两个十位数abcd,ab必须是偶数且能被5整除,cd必须是奇数,同时两个新数的十位数字均不为零,则将满足此条件的四位数按从大到小的顺序存入数组b中,并要计算满足上述条件的四位数的个数cnt。voidjsVal()

{

inti,j,k,A,B,C,D;for(i=0;iMAX;i++)

{ A=a/1000; B=a/10%10; C=a%10;D=a/100%10;if(A!=0C!=0(B==0)(D%2!=0)(10*A10*C+D))

b[cnt++]=a;

}

for(i=0;icnt-1;i++)

{k=i;

for(j=i+1;jcnt;j++)if(b[k]b[j])k=j;

if(k!=i){A=b[k];b[k]=b;b=A;}

} }

3、求符合条件的数的总和和平均值问题:求出千位数上的数减百位数上的数减

十位数上的数减个位数上的数大于零的个数cnt,再求出所有满足此条件的四位数平均值pjz1,以及所有不满足此条件的四位数平均值pjz2。

{

inti;

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

if(a/1000-a/100%10-a/10%10-a%100)

{cnt++;pjz1+=a;}elsepjz2+=a;if(cnt)pjz1/=cnt;

if(cnt300)pjz2/=300-cnt; }

4、求共有几个数以及各位数相加为基数的个数并求平均值问题:

1.求出这文件中共有多少个正整数totNum;2.求出这些数中的各位数字之和是奇

数的数的个数totCnt,以及满足此条件的这些数的算术平均值totPjz。

voidCalvalue(void)

{

while(xx[totNum]!=0)

{

if((xx[totNum]/1000+xx[totNum]/100%10+xx[totNum]/10%10+xx[totNum]

%10)%2)

{totCnt++;totPjz+=xx[totNum];}totNum++;

}

if(totCnt)totPjz/=totCnt;}

5、报数出圈voidJosegh(void)

{

inti,j,s1,w;s1=s;for(i=1;i=n;i++)p[i-1]=i;

for(i=n;i=2;i--)

{s1=(s1+m-1)%i;

if(s1==0)s1=i;w=p[s1-1];

for(j=s1;jI;J++)p[j-1]=p[j];

p[i-1]=w;}

6、以行为单位对行中以空格或标点符号为分隔的所有单词进行倒排,同时去除标点符号,之后把已处理的字符串(应不含标点符号)仍按行重新存入字符串数组xx中。voidStrOL(void)

{

inti,j,k,m,n,ll;charyy[80];

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

{ll=strlen(xx);k=n=0;for(j=ll-1;j=0;j--)

{if(isalpha(xx[j]))k++;else

{for(m=1;m=k;m++)yy[n++]=xx[j+m];

k=0;

}

if(xx[j]==)yy[n++]=;

}

for(m=1;m=k;m++)yy[n++]=xx[j+m];

/*上面两行处理每行的第一个单词。如果漏写,结果显然不正确,但并不影响得分。

*/yy[n]=0;

strcpy(

文档评论(0)

tianya189 + 关注
官方认证
内容提供者

该用户很懒,什么也没介绍

认证主体阳新县融易互联网技术工作室
IP属地上海
统一社会信用代码/组织机构代码
92420222MA4ELHM75D

1亿VIP精品文档

相关文档