您的当前位置:首页正文

C/C++游戏(game)

2024-11-20 来源:个人技术集锦

C/C++游戏(game)

题目描述
现在的游戏把趣味性和益智性结合得很好,最近你发现了一个很好玩的游戏。
电脑屏幕被平均分成N列,在屏幕的底端有一个M列宽的小船(M<N),在游戏过程中,玩家可以左右移动小船,但在移动过程中必须保证整个小船一直在屏幕内,不能移出屏幕。一开始,小船占据屏幕底端最左边M列。
有一些苹果从屏幕上方的某一列一直往下掉,直到到达屏幕的底端,在前一个苹果到达屏幕底端时,下一个苹果才开始往下掉。当苹果掉到底端时,如果小船正好占据着这一列,则认为该苹果被成功捡起。
游戏的目标是用最少的移动距离捡起所有掉下来的苹果。

输入
第一行输入两个空格隔开的整数N和M(1<=M<N<=10)。
第二行输入一个整数J(1<=J<=20)表示苹果的个数。
接下来J行每行一个整数,按照苹果下落顺序描述每个苹果的位置(列号)。

输出
输出要捡起所有苹果小船最少需要移动的距离。

样例输入
样例输入1
5 1
3
1
5
3
样例输入2
5 2
3
1
5
3
样例输出
样例输出1
6
样例输出2
4

这道题一看,有点意思。
先用用一个变量a存储每次苹果落下的列
然后用两个变量分别存储船的左边、右边。
接着每次输入a时判断苹果是否在小船范围内,若不在,就进行移动
而答案要求最短距离,所以只用船碰到边就行
最后输出答案
上C++代码:

#include<iostream>
using namespace std;
int n,m,a,ans;
int main()
{
	cin>>n>>m>>a;
	int l=1,r=m;
	for(int i=0;i<a;i++)
	{
		int s;
		cin>>s;
		if(s>r)
		{
			ans+=s-r;
			l+=(s-r);
			r=s;
		}
		else
		{
			if(s<l)
			{
				ans+=l-s;
				r-=(l-s);
				l=s;
			}
		}
	}
	cout<<ans;
	return 0;
}

C风格:

#include<stdio.h>
int n,m,a,ans;
int main()
{
	scanf("%d%d%d",&n,&m,&a);
	int l=1,r=m;
	for(int i=0;i<a;i++)
	{
		int s;
		scanf("%d",&s);
		if(s>r)
		{
			ans+=s-r;
			l+=(s-r);
			r=s;
		}
		else
		{
			if(s<l)
			{
				ans+=l-s;
				r-=(l-s);
				l=s;
			}
		}
	}
	printf("%d",ans);
	return 0;
}
显示全文