C语言程序设计编程题(二)19

1、编写程序实现s=1+2+…+n,n<10000;n由用户输入,输出s.

#include <stdio.h>
int main()
{
	int n,s,i;
	s=0;
	scanf("%d",&n);
	for(i=1;i<=n;i++)
		s+=i;
	printf("%d\n",s);
}

运行结果
在这里插入图片描述

2.假设黑白像素由二维矩阵表示,行数为M<5,列数为N<5,值分别用0或1表示。输出两幅相同大小速度黑白图像表示,求他们的相似度

  #include<stdio.h>


int main(){
	int row,col;  //行数,列数
	int sum,equal;      //sum为像素点总数; equal为像素点相同个数  
	double percentage;    //percentage为相似百分比
	int img1[4][4],img2[4][4];   //两个图像
	printf("输入图像行数,列数:");
	scanf("%d %d",&row,&col);
	sum = row * col;
	equal = 0;
	int i,j;

	//输入
	printf("img1:\n");
	for(i=0;i<row;i++){
		for(j=0;j<col;j++){
			scanf("%d",&img1[i][j]);
		}
	}

	printf("img2:\n");
	for(i=0;i<row;i++){
		for(j=0;j<col;j++){
			scanf("%d",&img2[i][j]);
		}
	}

	//计算
	for(i=0;i<row;i++){
		for(j=0;j<col;j++){
			if(img1[i][j] == img2[i][j])
				equal++;
		}
	}

	percentage = (double)equal/sum;
	printf("相似性:%.2f%%\n",percentage*100);
	
	return 0;
}

3、Pell数列a 1, a 2, a 3, …的定义是这样的,a 1 = 1, a 2 = 2, … , a n = 2 * a n − 1 + a n - 2 (n > 2)。
给出一个正整数k,要求Pell数列的第k项模上32767是多少。

#include<iostream>
#include<cstdio>
#include<cstdlib>
#include<cstring>
#define N 1000010
#define k 32767
using namespace std;
int a[N];
int f(int x)
{
	if(a[x]!=0) return a[x];
	if(x==1) return 1;
	if(x==2) return 2;
	return a[x]=(2*(f(x-1))%k+(f(x-2))%k)%k;
}
int main()
{
    int n,a;
	cin>>n;
	for(int i=1;i<=n;i++)
	{
		cin>>a;	
		cout<<f(a)<<endl;
	}
	return 0;
}

运行结果
在这里插入图片描述

4、二分法求函数零点
有函数:f(x) = x5 - 15 * x4+ 85 * x3- 225 * x2+ 274 * x - 121

已知 f(1.5) > 0 , f(2.4) < 0 且方程 f(x) = 0 在区间 [1.5,2.4] 有且只有一个根,请用二分法求出该根。

#include<iostream>
#include<cmath>
#include<iomanip>
using namespace std;
double f(double x)
{
    return pow(x,5)-15*pow(x,4)+85*pow(x,3)-225*pow(x,2)+274*x-121;
}
int main()
{
 int flag=0;
 double x1,x2,xx;
 x1=1.5,x2=2.4;
 while(x2-x1>=0.000001)
 {
   xx=(x1+x2)/2;
   if(f(xx)==0)
   {
    int flag=1;
    cout<<fixed<<setprecision(6)<<xx<<endl;
    break;
   }
   if(f(xx)*f(x1)<0)
      x2=xx;
  else
      x1=xx;  
 }
 if(!flag)
    cout<<fixed<<setprecision(6)<<x2<<endl;
 return 0;
}

运行结果
在这里插入图片描述

5、简单密码
Julius Caesar曾经使用过一种很简单的密码。对于明文中的每个字符,将它用它字母表中后5位对应的字符来代替,这样就得到了密文。比如字符A用F来代替。如下是密文和明文中字符的对应关系。
密文
A B C D E F G H I J K L M N O P Q R S T U V W X Y Z
明文
V W X Y Z A B C D E F G H I J K L M N O P Q R S T U
你的任务是对给定的密文进行解密得到明文。
你需要注意的是,密文中出现的字母都是大写字母。密文中也包括非字母的字符,对这些字符不用进行解码。

#include<stdio.h> 
#include<string.h> 
int main() 
{ 
	char s[201],end[201]; 
	char b[27]="VWXYZABCDEFGHIJKLMNOPQRSTU"; 
	int i,len; 
	gets(s); 
	while(strcmp(s,"START")==0) 
	{ 
		gets(s); 
		len=strlen(s); 
		for(i=0;i<len;i++) 
		{ 
			if(s[i]>='A'&&s[i]<='Z') 
			s[i]=b[s[i]-'A']; 
		} 
		gets(end); 
		printf("%s\n",s); 
		gets(s);
	}
}

运行结果
在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值