Part2: 补足程序,使程序符合题目要求并正确运行(共4道)
1.寻找两个整数之间的所有素数(包括这两个整数),把结果保存在数组bb中,函数返回素数的个数。 例如,输入6和21,则输出为: 7 11 13 17 19。
#include <stdio.h> #include <stdlib.h> #define N 1000 int fun(int n,int m,int bb[N]) { int i,j,k=0,flag; for(j=n;j<=m;j++) { flag=1; for(i=2;i<j;i++) if(j%i==0) { flag=0; break; } if(flag==1) bb[k++]=j; } return k; } int main(){ int n=0,m=0,i,k,bb[N]; scanf("%d",&n); scanf("%d",&m); for(i=0;i<m-n;i++) bb[i]=0; k=fun(n,m,bb); for(i=0;i<k;i++) printf("%4d",bb[i]); system("pause"); return 0; }
2.编程输出n阶左上拐角矩阵。
#include<stdio.h> #include<stdlib.h> #define N 100 void fun(int x[][N],int n) { int i,j; for(i=1;i<=n;i++) for(j=1;j<=n;j++) if( i<=j ) x[i][j]=i; else x[i][j]=j; } int main() { int n,i,j,a[N][N]; scanf("%d",&n); fun(a , n); for(i=1;i<=n;i++) { for(j=1;j<=n;j++) printf("%d ",a[i][j]); printf("\n"); } system("pause"); return 0; }
3.编程计算特定整数的偶数约束因子。 补足函数fun(), 函数的功能是: 找出能够被x整除并且是偶数的数,把这些数保存在数组bb中,并按从大到小的顺 序输出。 例如,当x=20时,依次输出: 20 10 4 2。
// 函数fun()的功能是: 找出能够被x整除并且是偶数的数, // 把这些数保存在数组bb中,并按从大到小的顺序输出。 // 例如,当x=20时,依次输出: 20 10 4 2。 #include <stdio.h> #include <stdlib.h> void fun(int k,int bb[]) { int i; int j=0; for(i=1; i<=k; i++) { if( k%i==0&&i%2==0 ) bb[j++]=i; } for(i=j-1; i>=0; i--) //一开始没发现是i=j-1 printf("%d ",bb[i]); } int main() { int x, *t; scanf("%d", &x); // 向系统申请sizeof(int)*x个字节的内存空间 // 如果申请成功,将系统分配的内存的首地址赋值给t t = (int *) malloc(sizeof(int)*x); fun(x,t); system("pause"); return 0; }
用冒泡排序算法实现对一组字符由大到小排序
#include <stdio.h> #include <stdlib.h> const int N=4; void output(char x[], int n); // 函数声明 // 排序函数声明 void mppx(char y []); int main() { char string[N] = {‘2‘,‘0‘,‘1‘,‘9‘}; int i; printf("排序前: \n"); output(string, N); // 调用排序函数对字符数组中的字符由大到小排序 // 补足代码2 mppx(string); printf("\n排序后: \n"); output(string, N); printf("\n"); system("pause"); return 0; } // 函数定义 // 函数功能描述:输出包含有n个元素的字符数组元素 // 形参:字符数组,以及字符数组元素个数 void output(char x[], int n) { int i; for(i=0; i<n; i++) printf("%c", x[i]); } // 函数定义 // 函数功能描述:对一组字符由大到小排序 // 形参:字符数组,以及字符数组元素个数 void mppx(char y[]){ int t; int b; int a; for(a=0;a<N-1;a++) for(b=0;b<N-a-1;b++) if(y[b]<y[b+1]){ t=y[b]; y[b]=y[b+1]; y[b+1]=t; } }
实验总结:1.循环的边界条件很重要也很容易错(我经常错),做题时可以带入数据进行尝试
2.数组的【】内的含义,不要搞混
3.根据条件找规律
原文:https://www.cnblogs.com/squidward/p/11961743.html