十一、作业

1.从大到小输出

写代码将三个整数数按从大到小输出。

void Swap(int* px, int* py)
{
	int tmp = *px;
	*px = *py;
	*py = tmp;

}
int main()
{
	int a = 0;
	int b = 0;
	int c = 0;
	scanf("%d %d %d", &a, &b, &c);

	int n = 0;
	if (a<b)
	{
		Swap(&a, &b);
	}
	if (a < c)
	{
		Swap(&a, &c);
	}
	if (b < c)
	{
		Swap(&b, &c);
	}
	printf("%d %d %d\n", a, b, c);
	return 0;
}
2.打印3的倍数的数

写一个代码打印1-100之间所有3的倍数的数字

int main()
{
	int i = 0;
	for ( i = 1; i <=100; i++)
	{
		if (i%3==0)
		{
			printf("%d ", i);

		}

	}
	return 0;
}

int main()
{
	int i = 0;
	for (i = 3; i <= 100; i+=3)
	{
		
			printf("%d ", i);


	}
	return 0;
}
3.最大公约数

给定两个数,求这两个数的最大公约数

//暴力求解法
int main()
{
	int a = 0;
	int b = 0;
	scanf("%d %d", &a, &b);
	int min = (a < b) ? a : b;
	int m = min;
	while (1)
	{
		if (a%m==0 && b%m==0)
		{
			break;
		}
		m--;
	}
	printf("%d\n", m);
	return 0;
}
//辗转相除法
int main()
{
	int a = 0;
	int b = 0;
	int c = 0;
	scanf("%d %d", &a, &b);
	
	while (c=a%b)
	{
		a = b;
		b = c;

	}
	printf("%d\n", b);
	return 0;
}

最小公倍数=a*b/最大公约数。

4.打印闰年

打印1000年到2000年之间的闰年

int main()
{
	int i = 0;
	for ( i = 1000; i <=2000; i++)
	{
		if ((i%4==0 && i%100 !=0) || (i%400==0))
		{
			printf("%d ", i);
		}
	}
	return 0;
}
5.二分查找

编写代码在一个整形有序数组中查找具体的某个数

要求:找到了就打印数字所在的下标,找不到则输出:找不到。

//二分查找
//
//编写代码在一个整形有序数组中查找具体的某个数
//
//要求:找到了就打印数字所在的下标,找不到则输出:找不到。
int main()
{
	int arr[10] = {1,2,3,4,5,6,7,8,9,10};
	int k = 7;
	int sz = sizeof(arr) / sizeof(arr[0]);
	int left =0;
	int right = sz-1;
	while (right>=left)
	{
		int mid = (right - left) / 2 + left;
		if (arr[mid]<k)
		{
			left = mid + 1;
		}
		else if (arr[mid] > k)
		{
			right = mid - 1;
		}
		else
		{
			printf("找到了下标为:%d\n", mid);
			break;
		}

	}
	if (right<left)
	{
		printf("找不到");

	}

	return 0;
}
6.数9的个数

编写程序数一下 1到 100 的所有整数中出现多少个数字9

int main()
{
	int i = 0;
	int count = 0;//计数
	for ( i = 1; i <=100; i++)
	{
		//判断个位是不是9
		if (i % 10 == 9)
			count++;
		//判断十位是不是9
		//因为有99两个9需要判断两次,不能用else if
		if (i / 10 == 9)
			count++;
	}
	printf("%d\n", count);
	return 0;
}
7.分数求和

计算1/1-1/2+1/3-1/4+1/5 ...... + 1/99 - 1/100 的值,打印出结果

int main()
{
	int i = 0;
	double sum = 0;
	int flag = 1;
	for ( i = 1; i <=100; i++)
	{
		sum=sum+flag*(1.0 / i);
		flag = -flag;

	}
	printf("%lf\n", sum);
	return 0;
}
8.求最大值

求10 个整数中最大值

int main()
{
	int arr[10] = {1,2,3,4,5,6,7,8,9,10};
	int i = 0;
	int max = arr[0];
	for ( i = 1; i <10; i++)
	{
		if (arr[i]>max)
			max = arr[i];

	}
	printf("最大的数值是:%d\n", max);

	return 0;
}

int main()
{
	int arr[10] = {0};
	int i = 0;
	for ( i = 0; i < 10; i++)
	{
		scanf("%d", &arr[i]);
	}
	int max = arr[0];
	for ( i = 1; i <10; i++)
	{
		if (arr[i]>max)
			max = arr[i];
	}
	printf("最大的数值是:%d\n", max);

	return 0;
}
9.乘法口诀表

在屏幕上输出9*9乘法口诀表

%2d - 右对齐

%-2d - 左对齐

/t - tab

//乘法口诀表
//
//在屏幕上输出9 * 9乘法口诀表

int main()
{
	int i = 0;
	//打印9行
	for ( i = 1; i <=9; i++)
	{
		//打印一行
		int j = 0;
		for ( j = 1; j<=i; j++)
		{
			printf("%d*%d=%-2d ", i, j, i * j);
		}
		printf("\n");	
	}

	return 0;
}
10.乘法口诀表(行列自己指定)
//乘法口诀表
//
//行列自己指定

void print_table(int n)
{

		int i = 0;
	//打印9行
	for ( i = 1; i <=n; i++)
	{
		//打印一行
		int j = 0;
		for ( j = 1; j<=i; j++)
		{
			printf("%d*%d=%-2d ", i, j, i * j);
		}
		printf("\n");	
	}
}
int main()
{
	int n = 0;
	scanf("%d", &n);
	print_table(n);
	return 0;
}
相关推荐
土豆湿5 分钟前
拥抱极简主义前端开发:NoCss.js 引领无 CSS 编程潮流
开发语言·javascript·css
小陈phd7 分钟前
Vscode LinuxC++环境配置
linux·c++·vscode
界面开发小八哥12 分钟前
更高效的Java 23开发,IntelliJ IDEA助力全面升级
java·开发语言·ide·intellij-idea·开发工具
火山口车神丶22 分钟前
某车企ASW面试笔试题
c++·matlab
qystca41 分钟前
洛谷 B3637 最长上升子序列 C语言 记忆化搜索->‘正序‘dp
c语言·开发语言·算法
薯条不要番茄酱41 分钟前
数据结构-8.Java. 七大排序算法(中篇)
java·开发语言·数据结构·后端·算法·排序算法·intellij-idea
今天吃饺子1 小时前
2024年SCI一区最新改进优化算法——四参数自适应生长优化器,MATLAB代码免费获取...
开发语言·算法·matlab
是阿建吖!1 小时前
【优选算法】二分查找
c++·算法
努力进修1 小时前
“探索Java List的无限可能:从基础到高级应用“
java·开发语言·list
Ajiang28247353043 小时前
对于C++中stack和queue的认识以及priority_queue的模拟实现
开发语言·c++