第九周练兵区——编程题——不计入总分

1二分法求根(4分)

用二分法求下面的一元三次方程在区间[-10, 10]上误差不大于的根。

在这里插入图片描述

用二分法求方程的根的基本原理是:若函数有实根,则函数曲线应当在根x*这一点上与x轴有一个交点,并且由于函数是单调的,在根附近的左右区间内,函数值的符号应当相反。利用这一特点,可以通过不断将求根区间二分的方法,每次将求根区间缩小为原来的一半,在新的折半后的区间内继续搜索方程的根,对根所在区间继续二分,直到求出方程的根为止。在这里插入图片描述
该方法的关键在于要解决如下两个问题:

1)如何对区间进行二分,并在二分后的左右两个区间中确定下一次求根搜索的区间?

假设区间端点为x1和x2,则通过计算区间的中点x0,即可将区间[x1, x2]二分为[x1, x0]和[x0, x2]。这时,为了确定下一次求根搜索的区间,必须判断方程的根在哪一个区间内,由上图可知方程的根所在区间的两个端点处的函数值的符号一定是相反的。也就是说,如果f(x0)与f(x1)是异号的,则根一定在左区间[x1, x0]内,否则根一定在右区间[x0, x2]内。

2)如何终止这个搜索过程?即如何确定找到了方程的根?

对根所在区间继续二分,直到,即|f(x0)|≈0时,则认为x0是逼近函数f(x)的根。

程序中所有变量的数据类型均为float。

输入格式: “%f,%f”

输出格式: “x=%6.2f\n”

输入样例:

0,4

输出样例:

x=__1.32

#include <stdio.h>
#include <math.h>
#define EPS 1e-6
int main()
{
	float x1, x2, fx0, x0, fx1, fx2;
	scanf("%f,%f", &x1, &x2);
              x0 = (x1+x2)/2;
		fx0 = x0*x0*x0 - x0 - 1;
	while(fabs(fx0)>EPS)
	{
		x0 = (x1+x2)/2;
		fx0 = x0*x0*x0 - x0 - 1;
		fx1 = x1*x1*x1 - x1 - 1;
		fx2 = x2*x2*x2 - x2 - 1;
		if(fx0 * fx1 < 0)
		{
			x2 = x0;
		}
		if(fx0 * fx2 < 0)
		{
			x1 = x0;
		}
	}
	printf("x=%6.2f\n", x0);
	return 0;
}

2矩阵转置(4分)

某二维数组存放的数据构成一个nn的方阵,其中n<=5。写程序,从键盘输入n的值(n<=5),该nn矩阵中各元素的值按下面的公式计算:

a[i][j] = i * n + j + 1

其中,a[i][j]表示第i行第j列的元素。要求分别输出该矩阵和它的转置矩阵。

注意:定义数字大小N时,请用

#define N 10

输入格式: “%d”

输出提示:“The original matrix is:\n”

输出提示:“The changed matrix is:\n”

输出格式: 矩阵的列与列之间为%3d,行与行之间为\n

输入样例1:

5↙

输出样例1:

The_original_matrix_is:

__1__2__3__4__5

__6__7__8__9_10

_11_12_13_14_15

_16_17_18_19_20

_21_22_23_24_25

The_changed_matrix_is:

__1__6_11_16_21

__2__7_12_17_22

__3__8_13_18_23

__4__9_14_18_24

__5_10_15_20_25

(输出样例中下划线“_”代表空格)

输入样例2:

4↙

输出样例2:

The original matrix is:

__1__2__3__4

__5__6__7__8

__9_10_11_12

_13_14_15_16

The changed matrix is:

__1__5__9_13

__2__6_10_14

__3__7_11_15

__4__8_12_16

#include<stdio.h>
#define N 10
main()
{
	int i,j,n,a[N][N];
	scanf("%d",&n);
	printf("The original matrix is:\n");
    for(i=0;i<n;i++){
		for(j=0;j<n;j++){
			a[i][j]=i*n+j+1;
	     printf("%3d",a[i][j]); 
		}
		printf("\n");
	}
   printf("The changed matrix is:\n");
		for(i=0;i<n;i++){
			for(j=0;j<n;j++){
				printf("%3d",a[j][i]);}
				printf("\n");}
		return 0;
}

3程序改错(4分)

下面程序的功能是从键盘任意输入n个数,然后找出其中的最大数与最小数,并将其位置对换。目前程序中存在错误,请修改正确。并按照给出的程序运行结果示例检查修改后的程序。

程序运行结果示例1:

Input n(n<=10):

5↙

Input 5 Numbers:

12 4 6 7 0↙

After MaxMinExchange:

0 4 6 7 12

程序运行结果示例2:

Input n(n<=10):

6↙

Input 6 Numbers:

7 -3 2 0 56 18↙

After MaxMinExchange:

7 56 2 0 -3 18

 #include  <stdio.h>
  #define ARR_SIZE 10
  int main()
  {
     int a[ARR_SIZE], i, n;
     printf("Input n(n<=10):\n");
     scanf("%d", &n);
     printf("Input %d Numbers:\n", n);
     for (i=0; i<n; i++)
     {
        scanf("%d", &a[i]);
     }
     MaxMinExchang(a, n);
    printf("After MaxMinExchange:\n");
     for (i=0; i<n; i++)
     {
        printf("%d ", a[i]);
     }
    printf("\n");
    return 0;
  }
  void  MaxMinExchang(int *a, int n)
 {
     int  maxValue = a[0], minValue = a[0], maxPos, minPos;
     int  i, temp;
     for (i=0; i<n; i++)
    {
       if (a[i] > maxValue)
        {
           maxValue = a[i];
           maxPos = i;
        }
        if (a[i] < minValue)
       {
            minValue = a[i];
            minPos = i;
        }
     } 
     temp = a[maxPos];
     a[maxPos] = a[minPos];
     a[minPos] = temp;
  }

输入提示信息: “Input n(n<=10):\n”

            "Input %d Numbers:\n"

输入格式: “%d”

输出格式:"%d " (注意:%d后面有一个空格)

输出提示信息:“After MaxMinExchange:\n”

#include  <stdio.h>
#define ARR_SIZE 10
void  MaxMinExchang(int a[ARR_SIZE], int n);
int main()
{
	int a[ARR_SIZE], i, n;
	printf("Input n(n<=10):\n");
	scanf("%d", &n);
	printf("Input %d Numbers:\n", n);
	for (i=0; i<n; i++)
	{
        scanf("%d", &a[i]);
	}
	MaxMinExchang(a, n);
    printf("After MaxMinExchange:\n");
	for (i=0; i<n; i++)
	{
        printf("%d ", a[i]);
	}
    printf("\n");
    return 0;
}
void  MaxMinExchang(int a[ARR_SIZE], int n)
{
	int  maxValue = a[0], minValue = a[0], maxPos=0, minPos=0;
	int  i, temp;
	for (i=0; i<n; i++)
    {
		if (a[i] > maxValue)
        {
			maxValue = a[i];
			maxPos = i;
        }
        if (a[i] < minValue)
		{
            minValue = a[i];
            minPos = i;
        }
	}
	temp = a[maxPos];
	a[maxPos] = a[minPos];
	a[minPos] = temp;
}

4蛇形矩阵(4分)

从键盘任意输入一个自然数n(n表示矩阵的大小,假设不超过100),请编程输出一个n*n的蛇形矩阵。如果输入的n不是自然数或者输入了不合法的数字,则输出"Input error!"。

函数原型: void ZigzagMatrix(int a[][N], int n);

函数功能:计算n*n的蛇形矩阵

提示:用两个双重循环分别计算n*n矩阵的左上三角和右下三角,设置一个计数器从1开始记录当前要写入矩阵的元素值,每次写完一个计数器加1,在计算左上角和右下角矩阵元素时,分奇数和偶数两种情况考虑待写入的元素在矩阵中的行列下标位置。

程序运行结果示例1:

Input n:

5↙

1 2 6 7 15

3 5 8 14 16

4 9 13 17 22

10 12 18 21 23

11 19 20 24 25

程序运行结果示例2:

Input n:

4↙

1 2 6 7

3 5 8 13

4 9 12 14

10 11 15 16

程序运行结果示例3:

Input n:

-5↙

Input error!

程序运行结果示例4:

Input n:

105↙

Input error!

程序运行结果示例5:

Input n:

w↙

Input error!

输入提示信息:“Input n:\n”

输入错误提示信息:“Input error!\n”

输入格式: “%d”

输出格式:"%4d"

数据换行: “\n”

#include<stdio.h>
#define N 100
void ZigzagMatrix(int a[][N], int n);
int main()
{
    int a[N][N] = {0};
    int n;
    a[0][0] = 1;
    printf("Input n:\n");
    if(!scanf("%d",&n) || n<=0 || n >100)   /* 清除非法输入 */
    {
        printf("Input error!");
    }
    else
    {
        ZigzagMatrix(a, n);    /* 调用输出蛇形矩阵的函数 */
    }

}

void ZigzagMatrix(int a[][N], int n)  /* 函数功能:输出蛇形矩阵 */
{
    int i, j, k, m;
    for(m = 1; m < 2*n - 2; m++)
    {
        if(m<=n-1)   /* 循环打印上三角 */
        {
            k = m;
            for(i = 0; i <= k; i++)
            {
                if(k%2)    /* k为偶数的情况 */
                {
                    if(i == 0)      /* 每个对角线开始打印的第一个和上一个衔接 */
                        a[i][k-i] = a[i][k-1] + 1;
                    else            /*  除了第一个,对角线的元素等于上一个元素加一1*/
                        a[i][k-i] = a[i-1][k-i+1] + 1;
                }
                else           /* 与k为偶数的情况类似 */
                {
                    if( i == 0)
                        a[k-i][i] = a[k-1][i] + 1;
                    else
                        a[k-i][i] = a[k-i+1][i-1] + 1;
                }
            }
        }
        else  /* 中心对称规律打印下三角 */
        {
            for(i = n-1; i >= 0; i--)
            {
                for(j = n-i; j < n; j++)
                    a[i][j] = n*n + 1 - a[n-1-i][n-1-j];
            }
        }

    }
    for(i = 0; i < n ;i++)     /* 输出蛇形矩阵 */
    {
        for(j = 0; j < n; j++)
        {
            printf("%4d",a[i][j]);
        }
        printf("\n");
    }
}

5亲密数_1(4分)

2500年前数学大师毕达哥拉斯就发现,220与284两数之间存在着奇妙的联系:

220的真因数之和为:1+2+4+5+10+11+20+22+44+55+110=284

284的真因数之和为:1+2+4+71+142=220

毕达哥拉斯把这样的数对称为相亲数。相亲数,也称为亲密数,如果整数A的全部因子(包括1,不包括A本身)之和等于B,且整数B的全部因子(包括1,不包括B本身)之和等于A,则将整数A和B称为亲密数。

从键盘任意输入两个整数m和n,编程判断m和n是否是亲密数。若是亲密数,则输出“Yes!”,否则输出“No!”

程序运行示例1

Input m, n:

220,284↙

Yes!

程序运行示例2

Input m, n:

224,280↙

No!

输入提示信息:“Input m, n:\n”

输入格式: “%d,%d”

输出格式:

输出提示信息:“Yes!\n”

          "No!\n"
#include<stdio.h>
int f(int n)
{  
     int r,sum=0;
     for(r=n-1;r>=1;r--){
         if(n%r==0)
         sum+=r;}
return sum;
}
main()
{
	int n,m;
	printf("Input m, n:\n");
	scanf("%d,%d",&m,&n);
	if(f(m)==n&&f(n)==m)
         printf("Yes!\n");
    else
         printf("No!\n");
   return 0;
}

6亲密数_2(4分)

2500年前数学大师毕达哥拉斯就发现,220与284两数之间存在着奇妙的联系:

220的真因数之和为:1+2+4+5+10+11+20+22+44+55+110=284

284的真因数之和为:1+2+4+71+142=220

毕达哥拉斯把这样的数对称为相亲数。相亲数,也称为亲密数,如果整数A的全部因子(包括1,不包括A本身)之和等于B,且整数B的全部因子(包括1,不包括B本身)之和等于A,则将整数A和B称为亲密数。

从键盘任意输入一个整数n,编程计算并输出n以内的全部亲密数。

程序运行示例1

Input n:

3000↙

(220,284)

(1184,1210)

(2620,2924)

程序运行示例2

Input n:

1000↙

(220,284)

输入提示信息:“Input n:\n”

输入格式: “%d”

输出格式: “(%d,%d)\n”

#include<stdio.h>
int f(int n)
{  
     int r,sum=0;
     for(r=n-1;r>=1;r--){
         if(n%r==0)
         sum+=r;}
return sum;
}
main()
{
	int i,n,m,t;
	printf("Input n:\n");
	scanf("%d",&n);
	for(i=1;i<=n;i++){
		m=f(i);
        t=f(m);
	if(t==i&&i<m)
         printf("(%d,%d)\n",i,m);
	}
   return 0;
}

7完全数(4分)

完全数(Perfect Number),又称完美数或完数,它是指这样的一些特殊的自然数。它所有的真因子(即除了自身以外的约数)的和,恰好等于它本身,即m的所有小于m的不同因子(包括1)加起来恰好等于m本身。注意:1没有真因子,所以1不是完全数。计算机已经证实在10300以下,没有奇数的完全数。例如,因为6 = 1 + 2 + 3,所以6是一个完全数。

从键盘任意输入一个整数m,编程判断m是否是完全数。若m是完全数,则输出“Yes!”,并同时打印出每一个完美数的全部因子,以验证这个数确实是一个完美数。若m不是完全数,则输出“No!”

程序运行示例1

Input m:

28↙

Yes!

1,2,4,7,14

程序运行示例2

Input m:

6↙

Yes!

1,2,3

程序运行示例3

Input m:

1↙

No!

输入信息提示:“Input m:\n”

输入格式: “%d”

输出格式:

输出格式: “%d”

输出信息提示:“Yes!\n”

          "No!\n"
#include<stdio.h>
main()
{
	int i,m,sum=0,a[10000]={0},r=0;
	printf("Input m:\n");
	scanf("%d",&m);
	for(i=1;i<m;i++)
	{
		if(m%i==0){
			a[r]=i;
			 r++;
			sum+=i;}
	}
	if(m==sum){
		printf("Yes!\n");
		for(i=0;i<r;i++){
			if(i<r-1)
		   printf("%d,",a[i]);
		    if(i==r-1)
			printf("%d",a[i]);}
	}
	else
		printf("No!\n");
	return 0;
}

8回文素数(4分)

所谓回文素数是指对一个素数n,从左到右和从右到左读是相同的,这样的数就称为回文素数,例如11,101,313等。编程计算并输出不超过n(100<=n<1000)的回文素数,并统计这些回文素数的个数,其中n的值从键盘输入。

程序运行示例1

Input n:

100↙

11

count=1

程序运行示例2

Input n:

1000↙

11 101 131 151 181 191 313 353 373 383 727 757 787 797 919 929

count=16

输入提示信息:“Input n:\n”

输入格式:"%d"

输出格式:

回文素数的输出格式:"%4d"

统计回文素数个数的输出格式: “\ncount=%d\n”

#include<stdio.h>
#include<math.h>
int f(int n)
{
	int j;
	for(j=2;j<n;j++)
	{
		if(n%j==0)
			return 0;
	}
	return 1;
}
main()
{
	int i,n,count=0,a,b,c;
    printf("Input n:\n");
	scanf("%d",&n);
	for(i=10;i<=n;i++){
		if(i<100)
		{
		  a=i/10;
		  c=i%10;
		}
		if(i>=100)
		{
			a=i/100;
			b=i/10%10;
			c=i%10;
		}
        if(a==c&&f(i))
		{
			printf("%4d",i);
			count++;
		}
	}
	printf("\ncount=%d\n",count);
return 0;
}

9梅森尼数(4分)

形如2i-1的素数,称为梅森尼数。编程计算并输出指数i在[2,n]中的所有梅森尼数,并统计这些梅森尼数的个数,其中n的值由键盘输入,并且n的值不能大于50。其中,2i表示2的i次方,请不要使用pow(2,i)编程计算,应采用循环累乘求积的方式计算2^i。

提示:当i 超过30以后,2^i-1的值会很大,不能用long型变量来存储,必须使用double类型来存储。对于double类型变量x(不是整型)不能执行求余运算,即不能用 x % i == 0来判断x是否能被i整除,可以使用 x / i == (int)(x/i)来判断x是否能被i整除。

程序运行示例:

Input n:

50↙

2^2-1=3

2^3-1=7

2^5-1=31

2^7-1=127

2^13-1=8191

2^17-1=131071

2^19-1=524287

2^31-1=2147483647

2^49-1=562949953421311

count=9

输入提示信息:“Input n:\n”

输入格式: “%d”

输出格式:

梅森尼数的输出格式: “2^%d-1=%.0lf\n”

统计梅森尼数个数的输出格式: “count=%d\n”

#include<stdio.h>
#include<math.h>
double f(double n)
{
	double i;
	if(n<=1)
		return 0;
	for(i=2;i<=sqrt(n);i++)
	{
		if(n/i==(int)(n/i))
			return 0;
	}
	return 1;
}
main()
{
	int  r,count=0,n;
	double t=1;
	printf("Input n:\n");
	scanf("%d",&n);
	for(r=1;r<n;r++)
	{
		t=t*2;
        if(f(t-1)){
		 count++;
		printf("2^%d-1=%.0lf\n",r,t-1);}
	}
	printf("count=%d\n",count);
  return 0;
}

10工资统计(4分)

某公司有职员(最多50人),试编写程序打印最高工资、最低工资和平均工资。公司人数在主函数给出,职工工资输入请调用Input函数,计算最高工资、最低工资和平均工资调用Compute函数,打印最高工资、最低工资和平均工资在主函数。请在给定的框架下写出完整程序。

#include<stdio.h>

void Input(float wage[], int n);

float Compute(float wage[], int n, float *pmaxwage, float *pminwage);

int main()

{

float wage[50],maxwage,minwage,avewage;

int n;



printf("Please input n:\n");

scanf("%d",&n);



Input(  ...  );     

avewage=Compute(  ...  );



printf("maxwage=%.2f, minwage=%.2f, avewage=%.2f\n",maxwage,minwage,avewage);



return 0;

}

void Input(float wage[], int n)

{

 ...

}

float Compute(float wage[], int n, float *pmaxwage, float *pminwage)

{

 ...

}

程序运行结果示例:

Please input n:

10↙

1200.34↙

2378.48↙

8600.56↙

5372.42↙

6317.25↙

7265.88↙

2156.39↙

1876.31↙

1792.14↙

4326.22↙

maxwage=8600.56, minwage=1200.34, avewage=4128.60

输入人数提示信息:“Please input n:\n”

人数输入格式:"%d"

工资输入格式:"%f"

输出格式:“maxwage=%.2f, minwage=%.2f, avewage=%.2f\n”

#include<stdio.h>
void Input(float wage[], int n);
float Compute(float wage[], int n, float *pmaxwage, float *pminwage);
int main()
{
    float wage[50],maxwage,minwage,avewage;
    int n;
    printf("Please input n:\n");
    scanf("%d",&n);
    Input(wage,n);     
    avewage=Compute(wage,n,&maxwage,&minwage);
    printf("maxwage=%.2f, minwage=%.2f, avewage=%.2f\n",maxwage,minwage,avewage);
    return 0;
}
void Input(float wage[], int n)
{
	int i;
	for(i=0;i<n;i++)
	scanf("%f",&wage[i]);
}
float Compute(float wage[], int n, float *pmaxwage, float *pminwage)
{
	int i;
	float p,sum=0;
	*pmaxwage=wage[0];
	*pminwage=wage[0];
	for(i=0;i<n;i++)
	{
		   sum+=wage[i];
		if(*pmaxwage<wage[i]){
			p=wage[i];
			wage[i]=*pmaxwage;
			*pmaxwage=p;}
		if(*pminwage>wage[i]){
			p=wage[i];
			wage[i]=*pminwage;
			*pminwage=p;}
	}
	return sum/n;
}
评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值