程序填写空白.docVIP

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

1.以下程序输入n,输出n个数的所有排列。 #include stdio.h #include stdlib.h void printlist( int a[], int n ) { /* 本函数输出数组a中的所有元素 */ int i; for ( i=0; in; i++ ) printf( %d\t, (4) ); printf(\n); } void swap( int *p, int *q ) { /* 本函数交换指针p和q所指向变量的值 */ int t; t=*p; *p=*q; *q=t; } main() { /* 输入n,并输出1至n各数值的所有排列 */ int n, *a, m, k, i, j; scanf( %d, n ); /* 输入变量n */ /* 申请n个int变量的内存空间*/ a = malloc( n*sizeof(int) ); /* 假设内存申请成功 */ /* 初始化第一个排列的值,按升序顺序 */ for ( i=0; in; i++ ) a[i] = i+1; /* 输出第一个排列 */ printlist( a, n ); /* 以下while语句无限循环直到输出所有排列 */ while ( 1 ) { /* 从右边找到第一个升序的数值下标给m */ /* 从a[m]至a[m+1]为升序,a[m+1]以后为降序 */ /* 在下一个排列中,a[m]应选择一个更大的数 */ m = n-2; while ( (m=0) (a[m]a[m+1]) ) m--; /* 如果所有元素为降序,则所有排列已输出,退出循环 */ if ( m0 ) (5) ; /* 从右边找到第一个正好超过a[m]的数,其下标为k */ /* 则a[k]是a[m]以后各元素中正好超过a[m]的一个值 */ k = n-1; while ( a[m] a[k] ) k--; /* 下一个排列时, a[m]应改为a[k],故交换a[m]与a[k] */ /* 交换后,从a[m+1]以后的数值仍为降序 */ swap( (6) ); /* 将从a[m+1]开始的其它元素按升序重新排列 */ /* 由于a[m+1]至a[n-1]为降序,故逆排a[m+1]以后各元素即可 */ for ( i=m+1,j=n-1; ij; i++,j-- ) swap( a+i, a+j ); /* 下一个排列的生成完毕,输出该排列 */ printlist( a, n ); } /* 释放开始时申请的内存空间 */ free( a ); } /* 输入 3 时,输出以下6个排列: 1 2 3 1 3 2 2 1 3 2 3 1 3 1 2 3 2 1 */ 2.以下程序将4至100的所有偶数分解为两个素数之和。 #include stdio.h int isprime(int n) { /*判断素数函数,若是返回1,否则返回0 */ int i; for (i=2;in;i++) if ( (1) ) return 0; return 1; } main() { int n,i; for (n=4;n100; (2) ) for (i=2;in;i++) if ( (3) ) { printf(%2d=%2d+%2d\t,n,i,n-i); break; } } 3.以下sort函数使用选择法对数组按从小到大排序。 #include stdio.h void sort(int a[],int n) { int i,j,k,t; for (i=0;in-1;i++) { for (k=j=i; jn; j++ ) if ( (1) ) k=j; if (k!=i) {t=a[k]; (2) ;a[i]=t;} } } main() { int a[10]={20,30,50,40,10,90,70,60,99,80},i; sort( (3) ); for (i=0;i10;i++) printf(%3d,a[i]); }/*运行后将输出: 10 20 30 40 50 60 70 80 90 99*/ 4.以下程序输入整数m和n,按每行7个数的格式输出m和n之间的所有素数(包括m和n)。 #include stdio.h main() { int m

文档评论(0)

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

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

1亿VIP精品文档

相关文档