C语言刷题(8)——“C”

各位CSDN的uu你们好呀,今天,小雅兰的内容是复习之前所学习的知识点,因为最近C语言马上就要更完啦,接下来,小雅兰会更新一些数据结构与算法的知识点,那么,复习最好的方式就是写题目,现在,让我们开始复习吧!!!


题目还是来源于牛客网 

编程语言初学训练营_在线编程+题解_牛客题霸_牛客网


BC93 统计数据正负个数

BC94 N个数之和

BC95 最高分与最低分之差

BC96 有序序列判断

BC98 序列中删除指定数字

BC99 序列中整数去重

BC100 有序序列合并

BC101 班级成绩输入输出

BC102 矩阵元素定位

BC103 序列重组矩阵

BC104 最高身高

BC105 矩阵相等判断


C语言刷题(8)——“C”_第1张图片

#define _CRT_SECURE_NO_WARNINGS 1
#include 
int main()
{
    int arr[10] = { 0 };
    int i = 0;
    for (i = 0; i < 10; i++)
    {
        scanf("%d ", &arr[i]);
    }
    int positive = 0;
    int negative = 0;
    for (i = 0; i < 10; i++)
    {
        if (arr[i] > 0)
        {
            positive++;
        }
        else if (arr[i] < 0)
        {
            negative++;
        }
    }
    printf("positive:%d\nnegative:%d", positive, negative);
    return 0;

}

 C语言刷题(8)——“C”_第2张图片

#include 
int main()
{
	int n = 0;
	scanf("%d", &n);
	int i = 0;
	int tmp = 0;
	int sum = 0;
	for (i = 0; i < n; i++)
	{
		scanf("%d", &tmp);
		sum += tmp;
	}
	printf("%d\n", sum);
	return 0;
}

C语言刷题(8)——“C”_第3张图片

#include 
int main()
{
	int n = 0;
	int max = 0;
	int min = 100;
	scanf("%d", &n);
	int i = 0;
	int tmp = 0;//存放每次读取的成绩
	for (i = 0; i < n; i++)
	{
		scanf("%d", &tmp);
		if (tmp > max)
		{
			max = tmp;
		}
		if (tmp < min)
		{
			min = tmp;
		}
	}
	printf("%d\n", max - min);
	return 0;
}

C语言刷题(8)——“C”_第4张图片

#include 
int main()
{
	int n = 0;
	int arr[50] = { 0 };
	scanf("%d", &n);
	int i = 0;
	int flag1 = 0;//升序
	int flag2 = 0;//降序
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr[i]);
		if (i > 0)
		{
			if (arr[i] > arr[i - 1])
			{
				flag1 = 1;
			}
			else if (arr[i] < arr[i - 1])
			{
				flag2 = 1;
			}
		}
	}
	//flag1 和 flag2 都为1是乱序的
	if (flag1 + flag2 > 1)
	{
		printf("unsorted\n");
	}
	else
	{
		printf("sorted\n");
	}
	return 0;
}

题目中设置2个标记变量,flag1,flag2,满足相邻2个元素升序把flag1设置为1,满足相邻2个元素降序把flag2设置为1.如果flag1和flag2都是1,那就是乱序。 

C语言刷题(8)——“C”_第5张图片

 C语言刷题(8)——“C”_第6张图片

#include
int main()
{
	int n = 0;
	int arr[50] = { 0 };
	int del = 0;//要删除的元素
	scanf("%d", &n);
	int i = 0;
	//读取n个数字
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr[i]);
	}
	//读取要删除的数字
	scanf("%d", &del);
	//删除的动作
	int j = 0;//记录存放数据位置的下标
	for (i = 0; i < n; i++)
	{
		if (arr[i] != del)
		{
			arr[j++] = arr[i];
		}
	}
	//此时的j就是删除元素后的数据个数
	for (i = 0; i < j; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

 要考虑删除多个相同的数字。

C语言刷题(8)——“C”_第7张图片

#include 
int main()
{
	int n = 0;
	int arr[5000] = { 0 };
	//输入数据
	scanf("%d", &n);
	int i = 0;
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr[i]);
	}
	//去重
	//后边的元素往前覆盖
	for (i = 0; i < n; i++)
	{
		int j = 0;
		for (j = i + 1; j < n; j++)
		{
			//先找出相同的元素
			//如果相等,要把后续元素往前移动
			if (arr[i] == arr[j])
			{
				int k = 0;
				for (k = j; k < n - 1; k++)
				{
					arr[k] = arr[k + 1];
				}
				n--;//去重一个,个数少1
				j--;
				//如果去重了arr[j]

				//把下一个位置的数字arr[j+1],放在新的arr[j]上

				//恰好又和arr[i]相同,所以也要再判断

				//3 2 3 3 3 4 5

				//

			}
		}
	}
	for (i = 0; i < n; i++)
	{
		printf("%d ", arr[i]);
	}
	return 0;
}

C语言刷题(8)——“C”_第8张图片

C语言刷题(8)——“C”_第9张图片

#include
int main()
{
	int n = 0;
	int m = 0;
	int arr1[100] = { 0 };
	int arr2[100] = { 0 };
	int arr3[200] = { 0 };//把两个数组合并之后的升序序列存储起来
	//输入n和m
	scanf("%d %d", &n, &m);
	//输入两个升序序列
	int i = 0;
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr1[i]);
	}
	for (i = 0; i < m; i++)
	{
		scanf("%d", &arr2[i]);
	}
	//合并有序序列
	i = 0;
	int j = 0;
	int k = 0;
	while (i < n && j < m)
	{
		if (arr1[i] < arr2[j])
		{
			arr3[k] = arr1[i];
			k++;
			i++;
		}
		else
		{
			arr3[k] = arr2[j];
			k++;
			j++;
		}
	}
	//若是数组遍历完了
	//第一个数组先遍历完
	if (i == n)
	{
		for (; j < m; j++)
		{
			arr3[k] = arr2[j];
			k++;
			j++;
		}
	}
	else if (j == m)//第二个数组先遍历完
	{
		for (; i < n; i++)
		{
			arr3[k] = arr1[n];
			k++;
			n++;
		}
	}
	//arr3打印
	for (i = 0; i < k; i++)
	{
		printf("%d ", arr3[i]);
	}
	return 0;
}

 但是这种写法是把两个数组合并并存放在了第三个数组中,显然,这个题目只需要合并并输出结果就行了,并不需要存储起来

先在2个数组中找较小的一次打印,等有一个数组中没有元素了,打印另外一个数组剩下的元素。

C语言刷题(8)——“C”_第10张图片

所以:这道题目还有另一种写法,可以不定义第三个数组

#include 
int main()
{
	int n = 0;
	int m = 0;
	int arr1[100] = { 0 };
	int arr2[100] = { 0 };
	//输入
	scanf("%d %d", &n, &m);
	int i = 0;
	for (i = 0; i < n; i++)
	{
		scanf("%d", &arr1[i]);
	}
	for (i = 0; i < m; i++)
	{
		scanf("%d", &arr2[i]);
	}
	//处理
	int j = 0;
	i = 0;
	while (i < n && j < m)
	{
		if (arr1[i] < arr2[j])
		{
			printf("%d ", arr1[i]);
			i++;
		}
		else
		{
			printf("%d ", arr2[j]);
			j++;
		}
	}
	if (i == n)
	{
		for (; j < m; j++)
		{
			printf("%d ", arr2[j]);
		}
	}
	else
	{
		for (; i < n; i++)
		{
			printf("%d ", arr1[i]);
		}
	}
	return 0;
}

 C语言刷题(8)——“C”_第11张图片

#include
int main()
{
	int i = 0;
	double score[5] = { 0 };
	for (i = 0; i < 5; i++)
	{
		//读取一个人的五科成绩
		int j = 0;
		double sum = 0.0;
		for (j = 0; j < 5; j++)
		{
			scanf("%lf", &score[j]);
			sum += score[j];
		}
		for (j = 0; j < 5; j++)
		{
			printf("%.1lf ", score[j]);
		}
		printf("%.1lf\n", sum);
	}
}

C语言刷题(8)——“C”_第12张图片

#include 
int main()
{
	int n = 0;
	int m = 0;
	int x = 0;
	int y = 0;
	scanf("%d %d", &n, &m);
	//这是C99语法-变长数组,但是数组不能初始化
	int arr[n][m];//具体给值也行
	int i = 0;
	int j = 0;
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			scanf("%d", &arr[i][j]);
		}
	}

	scanf("%d%d", &x, &y);
	printf("%d\n", arr[x - 1][y - 1]);
	return 0;
}

C语言刷题(8)——“C”_第13张图片

#include 
int main()
{
	int n = 0;
	int m = 0;
	int arr[10][10] = { 0 };
	scanf("%d %d", &n, &m);
	int i = 0;
	int j = 0;
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			scanf("%d", &arr[i][j]);
		}
	}
	//打印
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			printf("%d ", arr[i][j]);
		}
		printf("\n");
	}
	return 0;
}

另一种写法:

#include 
int main()
{
	int n = 0;
	int m = 0;
	int arr[10][10] = { 0 };
	scanf("%d %d", &n, &m);
	int i = 0;
	int j = 0;
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			scanf("%d", &arr[i][j]);
			printf("%d ", arr[i][j]);
		}
	}
	return 0;
}

另一种写法: 

#include 
int main()
{
	int n = 0;
	int m = 0;
	scanf("%d %d", &n, &m);
	int i = 0;
	int tmp = 0;
	for (i = 1; i <= m * n; i++)
	{
		scanf("%d", &tmp);
		printf("%d ", tmp);
		if (i % m == 0)
		{
			printf("\n");
		}
	}
	return 0;
}

C语言刷题(8)——“C”_第14张图片

#include
int main()
{
	int n = 0;
	int m = 0;
	scanf("%d %d", &n, &m);
	int i = 0;
	int j = 0;
	int max = 0;
	int x = 0;
	int y = 0;
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			int hi = 0;
			scanf("%d", &hi);
			if (hi > max)
			{
				x = i;
				y = j;
				max = hi;
			}
		}
	}
	printf("%d %d\n", x + 1, y + 1);
	return 0;
}

C语言刷题(8)——“C”_第15张图片

#include 
int main()
{
	int n = 0;
	int m = 0;
	scanf("%d%d", &n, &m);
	int arr1[10][10] = { 0 };
	int arr2[10][10] = { 0 };
	//输入第一个矩阵的数据
	int i = 0;
	int j = 0;
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			scanf("%d", &arr1[i][j]);
		}
	}
	//输入第二个矩阵的数据
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			scanf("%d", &arr2[i][j]);
		}
	}
	//比较两个数组的对应位置的元素
	for (i = 0; i < n; i++)
	{
		for (j = 0; j < m; j++)
		{
			if (arr1[i][j] != arr2[i][j])
			{
				printf("No\n");
				return 0;
			}
		}
	}
	printf("Yes\n");
	return 0;
}

好啦,小雅兰今天的复习内容就到这里啦,还要继续刷题,继续加油噢!!!

C语言刷题(8)——“C”_第16张图片

你可能感兴趣的:(C语言刷题,c语言,c++,开发语言)