NEUQ-ACM预备队week1

NEUQ-ACM预备队week1

主要内容:高精度算法

首先引入高精度,对其有个大概的了解:

在说高精度加减乘除运算之前,我们先搞明白什么是高精度运算?
实际上高精度就是说参与运算的数据和运算结果的范围,超出标准数据类型能表示的数据大小范围的运算。这个时候,如果要得到正确的计算结果,显然不能依靠普通方法实现了。而要在普通运算原理的基础上,加以辅助算法来实现超大数据的计算。例如:求两个100位的数据的和,或者计算两个100位的数字乘积。这时就要用到高精度算法了

大致解题思路

  1. 乒乓球:先模拟读入,再按照两种规则进行判比
  2. 高精度加法:用两个数组(或者按字符读入)分别存储两个加数,通过逆序整理,再按位相加,列竖式进行进位,最后去除尾部0,最终得到结果
  3. 高精度综合运算:高精加低精,高精乘高精,高精除低精的综合应用

1. 乒乓球

题目
国际乒联现在主席沙拉拉自从上任以来就立志于推行一系列改革,以推动乒乓球运动在全球的普及。
其中11分制改革引起了很大的争议,有一部分球员因为无法适应新规则只能选择退役。
华华就是其中一位,他退役之后走上了乒乓球研究工作,意图弄明白11分制和21分制对选手的不同影响。
在开展他的研究之前,他首先需要对他多年比赛的统计数据进行一些分析,所以需要你的帮忙。
华华通过以下方式进行分析,首先将比赛每个球的胜负列成一张表,然后分别计算在11分制和21分制下,双方的比赛结果(截至记录末尾)。 
比如现在有这么一份记录,(其中W表示华华获得一分,L表示华华对手获得一分): 
WWWWWWWWWWWWWWWWWWWWWWLW 
在11分制下,此时比赛的结果是华华第一局11比0获胜,第二局11比0获胜,正在进行第三局,当前比分1比1。
而在21分制下,此时比赛结果是华华第一局21比0获胜,正在进行第二局,比分2比1。
如果一局比赛刚开始,则此时比分为0比0。 
你的程序就是要对于一系列比赛信息的输入(WL形式),输出正确的结果。
输入格式:
每个输入文件包含若干行字符串(每行至多20个字母),字符串由大写的W、L和E组成。
其中E表示比赛信息结束,程序应该忽略E之后的所有内容。

输出格式:
输出由两部分组成,每部分有若干行,每一行对应一局比赛的比分(按比赛信息输入顺序)。
其中第一部分是11分制下的结果,第二部分是21分制下的结果,两部分之间由一个空行分隔。

输入样例:
WWWWWWWWWWWWWWWWWWWW
WWLWE
输出样例:
11:0
11:0
1:1

21:0
2:1
题解
#include<bits/stdc++.h>
using namespace std;
const int N = 10005;
int a[N];
int main()
{
    
	char c;int idx;
	while(cin>>c&&c!='E')
	{
		if(c=='W') a[++idx]=1;     //数组读入
		else a[++idx]=0;
	}
	int x=0,y=0;
	for(int i=1;i<=idx;++i){
		if(a[i]) x++;
		else y++;
		if(abs(x-y)>=2&&(x>=11||y>=11)){
			cout<<x<<":"<<y<<endl;
			x=0,y=0;
		}
	}
	if(x!=0||y!=0) cout<<x<<":"<<y<<endl;
	x=0,y=0;cout<<endl;
	for(int i=1;i<=idx;++i){
		if(a[i]) x++;
		else y++;
		if(abs(x-y)>=2&&(x>=21||y>=21)){    //两种计分方式,分别评判
			cout<<x<<":"<<y<<endl;
			x=0,y=0; 
		}
	}
	if(x!=0||y!=0) cout<<x<<":"<<y<<endl;
	return 0;
}

2. 高精度加法

题目
对于输入的两个不超过100位数字的非负整数,给出两数之和。

输入格式:
在两行中分别给出两个不超过100位数字的非负整数

输出格式:
在一行中输出两数之和

输入样例:
123
12
输出样例:
135
题解
#include<bits/stdc++.h>
using namespace std;
const int N = 105;
char x[N],y[N];
int a[N],b[N],c[N];
int main()
{
    cin >> x >> y;
    int lx=strlen(x),ly=strlen(y);
    for(int i=1;i<=lx;++i) a[i]=x[lx-i]-'0';
    for(int i=1;i<=ly;++i) b[i]=y[ly-i]-'0';     //字符转数字
    int len=max(lx,ly)+1;
    for(int i=1;i<=len;++i) c[i]=a[i]+b[i];
    for(int i=1;i<=len;++i)
    if(c[i]>=10){
    	c[i+1]+=c[i]/10;              //列竖式理解,进位计算
    	c[i]%=10;
	}
	while(c[len]==0&&len>1) len--;
	for(int i=len;i>=1;i--) cout<<c[i];

    return 0;
} 

3. 高精度综合运算累加和

题目
使用求和公式求1到N的累加和大家都会,但是如果把N值变大呢,比如100位的整数,那该怎么求?

输入格式:
输入在一行中给出1个位数不超过100位的整数N。

输出格式:
对每一组输入,在一行中输出1+2+3+……+N的值。

输入样例:
在这里给出一组输入。例如:

10
输出样例:
在这里给出相应的输出。例如:

55
题解
#include<bits/stdc++.h>
using namespace std;
void addd(int S[]) {
	for(int i=0; i<205; i++) {
		if(S[i]>=10) {
			S[i+1]+=S[i]/10;
			S[i]=S[i]%10;
		}
	}
}
int main() {
	string n;
	cin>>n;
	int N[101];
	memset(N,0,sizeof(N));
	for(int i=n.length()-1; i>=0; i--) {
		int n1;
		n1=n[n.length()-1-i]-'0';
		N[i]=n1;
	}
	int M[101];
	for(int i=0;i<101;i++){
		M[i]=N[i];
	}
	M[0]++;
	for(int i=0;i<101;i++){
		if(M[i]==10){
			M[i]=0;
			M[i+1]++;
		}
	}
	int S[205];
	memset(S,0,sizeof(S));
	for(int i=0;i<n.length();i++){
		for(int j=0;j<n.length()+1;j++){
			S[i+j]+=N[i]*M[j];
		}
	}
	addd(S);
	int f=0;
	for(int i=204; i>=0; i--) {
		if(i>0&&S[i]%2!=0)	S[i-1]+=10;
		S[i]/=2;
		if(S[i]>0||f==1){		
			cout<<S[i];
			f=1;
		}
	}
	return 0;
}

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值