[华为编程大赛1.docVIP

  1. 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
  2. 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载
  3. 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
  4. 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
  5. 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们
  6. 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
  7. 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
[华为编程大赛1

2011年华为杯校园编程大赛A卷 类别:软件C语言 编程题(共3题,第一题20分,第二题30分,第三题50分,共100分。请上机编写程序,按题目要求提交文件。?[详见考试说明] 本试题采用自动测试用例进行评分,测试用例不对考生公开,凡不满足提交要求导致不能运行或用例不通过,不予评分)。 矩阵转置(20分) 问题描述 将一个N*N矩阵的行列互换 要求实现函数 void MatrixTranspose (const char *InArr, unsigned int n, const char *OutArray) 【输入】InArr:??输入的字符矩阵 n:???N*N矩阵的行数 【输出】OutArray:?转置后的字符矩阵 【返回】 无 注:输入输出的矩阵都是以一维形式保存的二维数组, 比如输入为{‘1’,?‘2’,?‘3’,?‘4’,?‘5’,?‘6’,?‘7’,?‘8’,?‘9’}, 实际上表示如下3*3的矩阵 ‘1’,’2’,’3’, ‘4’,’5’,’6’, ‘7’,’8’,’9’ 示例 输入InArr = {‘1’,?‘2’,?‘3’,?‘4’,?‘5’,?‘6’,?‘7’,?‘8’,?‘9’},n=3 输出OutArray = {‘1’,’4’,’7’,’2’,’5’,’8’,’3’,’6’,’9’} #include stdio.h void matrix(char *in,int n, char* out) { int i,j; int k=0; for(i=0;in;i++) for(j=i;jn*n;j+=n) out[k++]=in[j]; } void main() { char a[9]={1,2,3,4,5,6,7,8,9}; char b[9]; matrix(a,3,b); for(int i=0;i9;i++) printf(%c,b[i]); } 2、出圈问题(30分) 问题描述 M个人围成一圈报数,数到N(1N10)的倍数或包含N这个数字时出圈,问剩下的最后一个人在原来的位置是多少? 报数规则: 1、从第一个人开始报数为1,下一个人报数为上一个人报数加1 2、报数的最大值为2000,如果报数超过2000,则下一个人重新从1开始报数 要求实现函数 int OutFunc (unsigned int iTotalNum, unsigned int iKey) 【输入】iTotalNum:?开始报数前的总人数,?0iTotalNum65535 ?????iKey: ????题目中要求的数目N 【输出】无 【返回】剩下的人的原来的位置 示例 输入:iTotalNum =5, ?iKey =3 返回:4 输入:iTotalNum =15, ?iKey =3 返回:10 #include stdio.h #include stdlib.h typedef struct node { int data; struct node *next; }NODE ,* LINK; int outfunc(unsigned int total,unsigned int key) { bool flag=false; int count=0; LINK head=NULL; LINK p1,p2; for(int i=1;itotal+1;i++) { p1=(LINK)malloc(sizeof(NODE)); p1-data=i; if(head==NULL) { head=p1; p2=p1; } else { p2-next=p1; p2=p1; } } p1-next=head; p1=head; p2=p1; while(p1-next!=p1) { for(i=1;i2001;i++) { int temp=i; while(temp) { int left=temp%10; temp=temp/10; if(left==key) { flag=true; break; } } if(flag||(i%key==0)) { p2-next=p1-next; free(p1); } p2=p1; p1=p1-next; if(p1-next==p1) break; } } return p1-data; } void main() { int a=15; int b=3; i

文档评论(0)

tiantiande + 关注
实名认证
文档贡献者

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

1亿VIP精品文档

相关文档