牛客网每日五题(二)

每日五题第二天

持之以恒


1.最大公约数与最小公倍数之和问题

解题思路:ab=最大公约数最小公倍数

#include<stdio.h>
int main()
{
	int n, m;
	scanf("%d %d", &n, &m);
	if (n < m)
	{
		int t = n;
		n = m;
		m = t;
	}
	int p = m * n;
	while (m != 0)
	{
		int r = n % m;
		n = m;
		m = r;
	}
	printf("%d", n + p / n);
	return 0;
}

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


2.[NOIP2015]金币问题

此题唯一需要注意的点则是n<=k应该写在外层for中,不必每次均在while中

#include<stdio.h>
int main()
{
	int k = 0;
	scanf("%d", &k);//天数
	int i = 0, j = 0, n = 1, c = 0;//c:金币个数
	for (i = 1; n <= k; i++)
		for (j = 0; j < i; j++)
		{
			if (n > k)
				break;
			c += i;
			n++;
		}
	printf("%d", c);
	return 0;
}

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


3.输入N个数字求和

在寻常的vs中,变长数组可能会报错,所以这里是采用的c99语言中的变长数组来解决问题
源码如下:

#include<stdio.h>
int main()
{
	int N = 10, s = 0, i = 0;
	int arr[10];//因为c语言不支持arr[n],所以博主用10来代替n
	for (i = 0; i < 10; i++)
	{
		scanf("%d", &arr[i]);
		s += arr[i];
	}
	printf("%d", s);
	return 0;
}

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


4.有序数组插入一个数

有很多同学在写for循环时习惯用++,但有时候–可能会比++更好用的,注意甄别

#include<stdio.h>
int main()
{
	int i = 0, n, x, a[51];
	scanf("%d%d", &n, &x);
	for (i = 1; i <= n; i++)
		scanf("%d", &a[i]);
	for (i = n; i > 0; i--)
	{
		if (x > a[i])
		{
			a[i + 1] = x;
			break;
		}
		else
		{
			a[i + 1] = a[i];
			a[i] = x;//将与x比较的数后移,x占用原来位置
		}
	}
	for (i = 1; i <= n + 1; i++)
		printf("%d", a[i]);
	return 0;
}

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


5.序列中整数去重

话不多说上代码

#include<stdio.h>
int main()
{
	int i, j, k, n, a[1000];
	scanf("%d", &n);
	for (i = 0; i < n; i++)
		scanf("%d", &a[i]);
	for(i=0;i<n;i++)
		for (j = i + 1; j < n; j++)
		{
			if (a[i] == a[j])
			{
				for (k = j + 1; k < n; k++)
					a[k - 1] = a[k];
				n--;
				j--;
			}
		}
	for (i = 0; i < n; i++)
		printf("%d ", a[i]);
	return 0;
}

运行结果如下
在这里插入图片描述
今天五题结束咯,明天见

评论 4
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

c.night

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值