C语言之练手题

题目1:

思路:我们定义两个变量left和right分别为数组的左端下标和右端下标。
左端下标的元素为奇数时,left++继续往前走,为偶数时就停下
右端下标的元素为偶数时,right- -往回走,为奇数时停下
停下后对应的元素交换。

代码实现如下:

c 复制代码
#include <stdio.h>

void Num_round(int arr[], int sz)
{
	int left = 0;
	int right = sz - 1;
	while (left < right)
	{
		//1.left指向为奇数,往前走,遇到偶数停下来
		while (left < right && arr[left] % 2 != 0)
		{
			left++;
		}
		//2..right指向为偶数,往后走,遇到奇数停下来
		while (left < right && arr[right] % 2 == 0)
		{
			right--;;
		}
		//3.停下来后两者进行交换
		int tmp = arr[left];
		arr[left] = arr[right];
		arr[right] = tmp;
	}
}

int main()
{
	int arr[] = { 1,2,3,4,5,6,7 };
	int sz = sizeof(arr) / sizeof(arr[0]);
	Num_round(arr, sz);
	for (int i = 0; i < sz; i++)
	{
		printf("%d ", arr[i]);
	}

	return 0;
}

题目2:

思路:只有当空瓶>1个时,才可以换饮料:

代码实现如下:

c 复制代码
#include <stdio.h>

int main()
{
	int money = 0;
	scanf("%d", &money);
	int empty = money;
	int total = money;
	while (empty > 1)
	{
		total = total + empty / 2;
		empty = empty / 2 + empty % 2;
	}
	printf("%d\n", total);

	return 0;
}

题目3:

思路:通过观察每一项,我们可知:

代码实现如下:

c 复制代码
#include <stdio.h>

int main()
{
	int a = 0;
	scanf("%d", &a);
	int sum = 0;
	int tmp = 0;
	for (int i = 0; i < 5; i++)
	{
		tmp = tmp * 10 + a;
		sum += tmp;
	}
	printf("%d\n", sum);

	return 0;
}

题目4:

思路:
这里需要注意的是右移的位数。

c 复制代码
#include <stdio.h>

 void Func(int n)
{
	//偶数位
	for (int i = 31; i >= 1; i-=2)
	{
		printf("%d ", (n >> i) & 1);
	}
	printf("\n");
	//奇数位
	for (int i = 30; i >= 0; i -= 2)
	{
		printf("%d ", (n >> i) & 1);
	}
}

int main()
{
	int n = 0;
	scanf("%d", &n);
	Func(n);
	return 0;
}
相关推荐
蜜獾云16 分钟前
设计模式之构造器模式:封装复杂对象的构造逻辑
java·开发语言·设计模式
娇娇yyyyyy1 小时前
Qt编程(3): 信号和槽函数
开发语言·数据库·qt
wwww.wwww1 小时前
qt程序执行时报错:无法定位程序输入点,但是通过IDE的run又可以正常的运行。
开发语言·ide·qt
乌鸦乌鸦你的小虎牙4 小时前
qt 5.12.8 配置报错(交叉编译环境)
开发语言·数据库·qt
feifeigo1234 小时前
Leslie人口模型MATLAB实现(中长期人口预测)
开发语言·matlab
写代码的二次猿5 小时前
安装openfold(顺利解决版)
开发语言·python·深度学习
一只大袋鼠5 小时前
Redis 安装+基于短信验证码登录功能的完整实现
java·开发语言·数据库·redis·缓存·学习笔记
※DX3906※6 小时前
Java排序算法--全面详解面试中涉及的排序
java·开发语言·数据结构·面试·排序算法
笨笨马甲6 小时前
Qt QSS使用指南
开发语言·qt
We་ct7 小时前
LeetCode 77. 组合:DFS回溯+剪枝,高效求解组合问题
开发语言·前端·算法·leetcode·typescript·深度优先·剪枝