苏嵌第六天(习题)

1、 题目:通过编程实现,统计1~n有多少个9

       提示:n通过参数传入

#include<stdio.h>

int count(int x)
{
	int i = 0, j, n;
	n = x;
	for (; n>0; n--)
	{
		if (9 == (n % 10))
		{
			i++;
		}
		x = n;
		while (x)
		{
			j = x / 10;
			x = j;
			if (9 == (j % 10))
			{
				i++;
			}
		}
	}
	return i;
}
main()
{
	int n, a;
	printf("请输入一个数字:\n");
	scanf("%d", &n);
	a = count(n);
	printf("1-%d有%d个9\n", n, a);

}

2、 题目:有n个人围成一圈,顺序排号,从第一个开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。

       提示:用数组完成

#include <stdio.h> 
#define n 4 
void main()
{
	int a[n], i, quit_num, k;
	for (i = 0; i<n; i++)/*数组a存放原始编号*/
	{
		a[i] = i + 1;
	}
	quit_num = 0;/*出圈人数*/
	i = 0;
	k = 0;
	while (quit_num<n - 1)/*直到只剩下1人时*/
	{
		if (a[i] != 0)
		{
			k++;
		}
		if (k == 3)
		{
			a[i] = 0;
			quit_num++;
			k = 0;
		}
		i++;
		if (i == n)
		{
			i = 0;
		}
	}
	for (i = 0; i<n; i++)


	{
		if (a[i] != 0)
		{
			printf("第%d个人留到最后\n", a[i]);
		}
	}

}

3、 题目:输入5个数(含负数、小数)将它们按由大到小的顺序排列起来

提示:需要排数的数字通过参数传递进来

例如:输入:./a.out -1 2.1 -3 5 7 输出:-3 -1 2.1 5 7

#include<stdio.h>
#define SIZE 100
int j;
void input(float *b)
{
	int i;
	printf("输入要输入的数字的个数\n");
	scanf("%d", &j);
	printf("输入数据\n");
	for (i = 0; i<j; i++)
	{
		scanf("%f", &b[i]);
	}
}
void sort(float *b)
{
	int i, m;
	float num;
	for (i = 0; i<j - 1; i++)
	{
		for (m = 0; m<j - 1; m++)
		{
			if (b[m]>b[m + 1])
			{
				num = b[m];
				b[m] = b[m + 1];
				b[m + 1] = num;
			}
		}
	}
}
void print(float *b)
{
	int i;
	for (i = 0; i<j; i++)
	{
		printf("%f ", b[i]);
	}
}
main()
{
	float a[SIZE] = { 0 };
	input(a);
	sort(a);
	print(a);

}

4、题目:求100以内的素数,全部打印出来

#include<stdio.h>

int main()
{
	int i;
	int j = 1;

	for (i = 2; i <= 100; i++)
	{
		for (j = 2; j<i; j++)

			if (i%j == 0)
			{
				break;
			}
		if (j == i)
		{
			printf("%d ", i);
		}
	}
	printf("\n");
	while (1);
	return 0;
}

5、 题目:一个数如果恰好等于它的因子之和,这个数被称为“完数”,

       例如:6=1+2+3.

       请编程找出1000以内的完数

扫描二维码关注公众号,回复: 2314741 查看本文章
#include<stdio.h>

int main()
{
	int i, sum, n;

	for (n = 1; n <= 1000; n++)
	{
		sum = 0;
		for (i = 1; i<n; i++)
		{
			if (n%i == 0)
			{
				sum = sum + i;
			}
		}

		if (n == sum)
		{
			printf("%d 它的因子 : \n", n);

			for (i = 1; i<n; i++)
			{
				if (n%i == 0)
				{
					printf("%d", i);
				}
			}
			printf("\n");
		}
	}
	while (1);
	return 0;
}


猜你喜欢

转载自blog.csdn.net/myoath7/article/details/81047120