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以内的完数
#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;
}