实验题,总是不对
【C0369】应用函数输出给定正整数的因子展开式
完成程序,设计实现函数void solve(int x) ,其功能为输出一个给定正整数x(x>1)的质因子展开式。
函数接口定义:
void solve(int x);/功能为输出一个给定正整数x(x>1)的质因子展开式/
裁判测试程序样例:
#include <stdio.h>
/* 请在这里填写答案 */
int main(){
void solve(int);
int x;
scanf("%d",&x);
if(x<2) printf("error data");
else{
printf("%d=",x);
solve(x);
}
return 0;
}
输入格式:
请在一行中输入整数x的值。
输出格式:
对每一组输入的x,按以下格式输出x的质因子展开式(假如x的质因子分别为a、b、c):
x=abc
输入样例1:
72
输出样例1:
72=22233
输入样例2:
1
输出样例2:
error data
输入样例3:
5
输出样例3:
5=5
【C0371】应用函数实现矩阵乘法
完成程序,设计实现函数void f(int a[],int b[],int c[],int m,int n,int t),其功能为计算给定的两个整型数组(一个为m行n列,一个为n行t列)的乘积矩阵。
函数接口定义:
void f(int a[],int b[],int c[],int m,int n,int t);/功能为计算给定的矩阵a(m行n列)和矩阵b(n行t列)的乘积矩阵c/
裁判测试程序样例:
#include <stdio.h>
/* 请在这里填写答案 */
int main(){
int i,j,a[3][4],b[4][3],c[3][3];
for(i=0; i<3; i++)
for(j=0; j<4; j++)
scanf("%d",&a[i][j]);
for(i=0; i<4; i++)
for(j=0; j<3; j++)
scanf("%d",&b[i][j]);
f(a[0],b[0],c[0],3,4,3);
for(i=0; i<3; i++){
for(j=0; j<3; j++)
printf("%5d",c[i][j]);
printf("\n");
}
}
输入格式:
首先输入整型数组a[3][4]的各元素的值,再输入整型数组b[4][3]的各元素的值,数据中间以空格为间隔。
输出格式:
对于输入的a数组和b数组,输出a和b的乘积矩阵c[3][3],其中每个元素显示格式为:占5列,右对齐。
输入样例:
1 2 3 4
2 3 4 5
3 4 5 6
1 2 3
2 3 4
3 4 5
4 5 6
输出样例:
30 40 50
40 54 68
50 68 86
6-3 【C0373】应用递归函数实现起泡排序
完成程序,设计实现递归函数void sort(int a[],int n),其功能为使用“起泡法”对a数组存储的n(n<=20)个数按从大到小排序,排列后任然存储a数组中。
函数接口定义:
void sort(int a[],int n);/*功能为使用“起泡法”对a数组存储的n(n<=20)个数按从大到小排序,排列后任然存储a数组中*/
裁判测试程序样例:
#include <stdio.h>
#define N 20
/* 请在这里填写答案 */
int main(){
int a[N],i,n;
scanf("%d",&n);
if(n>20) printf("error data");
else{
for(i=0; i<n; i++)
scanf("%d",&a[i]);
sort(a,n);
for(i=0; i<n; i++)
printf("%5d",a[i]);
printf("\n");
}
return 0;
}
输入格式:
请在第一行中输入整数n的值,表示数据的个数。
在第二行中输入n个无序整数,数据中间以空格为间隔。
输出格式:
对每一组输入的n个无序整数,输出按照从小到大顺序的排序结果,其中每个数显示格式为:占5列,右对齐。
输入样例1:
10
1 2 3 4 5 0 9 8 7 6
输出样例1:
9 8 7 6 5 4 3 2 1 0
输入样例2:
45
输出样例2:
error data