本文参考自: 原文地址
1、 题目:通过编程实现,统计1~n有多少个9
提示:n通过参数传入
#include<stdio.h>
int main()
{
int num, i, key=0, m=0, k=0;
printf("please input num :\n");
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
k = i;
do {
key = k % 10;
if (key == 9)
{
m = m + 1;
}
k = k / 10;
} while (k>0);
}
printf("%d\n", m);
while (1);
return 0;
}
提示:n通过参数传入
#include<stdio.h>
int main()
{
int num, i, key=0, m=0, k=0;
printf("please input num :\n");
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
k = i;
do {
key = k % 10;
if (key == 9)
{
m = m + 1;
}
k = k / 10;
} while (k>0);
}
printf("%d\n", m);
while (1);
return 0;
}
2、 题目:有n个人围成一圈,顺序排号,从第一个开始报数(从1到3报数),凡报到3的人退出圈子,问最后留下的是原来第几号的那位。
提示:用数组完成
#include<stdio.h>
int main()
{
int i, k, count;
int a[100];
提示:用数组完成
#include<stdio.h>
int main()
{
int i, k, count;
int a[100];
for (i = 0; i<100; i++);
{
{
a[i] = i + 1;
}
i = 0;
k = 0; //读数
count = 0;
while (count<100 - 1) //当被踢出的人的个数达到n-1的时候跳出while();
{
if (a[i] != 0)
{
k++;
}
if (k == 3)
{
k = 0;
count++;
a[i] = 0;
}
i++;
if (i == 100)
{
i = 0;
}
}
for (i = 0; i<100; i++)
{
if (a[i] != 0)
{
printf("%d", a[i]);
}
}
while (1);
return 0;
}
}
i = 0;
k = 0; //读数
count = 0;
while (count<100 - 1) //当被踢出的人的个数达到n-1的时候跳出while();
{
if (a[i] != 0)
{
k++;
}
if (k == 3)
{
k = 0;
count++;
a[i] = 0;
}
i++;
if (i == 100)
{
i = 0;
}
}
for (i = 0; i<100; i++)
{
if (a[i] != 0)
{
printf("%d", a[i]);
}
}
while (1);
return 0;
}
3、 题目:输入5个数(含负数、小数)将它们按由大到小的顺序排列起来
提示:需要排数的数字通过参数传递进来
例如:输入:. / a.out - 1 2.1 - 3 5 7 输出: - 3 - 1 2.1 5 7
#include<stdio.h>
int main()
{
float a[5];
int i, j;
float temp;
printf("please input 5 numbers :\n");
提示:需要排数的数字通过参数传递进来
例如:输入:. / a.out - 1 2.1 - 3 5 7 输出: - 3 - 1 2.1 5 7
#include<stdio.h>
int main()
{
float a[5];
int i, j;
float temp;
printf("please input 5 numbers :\n");
for (i = 0; i<5; i++)
{
scanf("%f", &a[i]);
}
for (i = 0; i<5; i++)
{
for (j = 0; j<5; j++)
{
if (a[j]<a[i])
{
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
}
printf("the result is : \n");
{
scanf("%f", &a[i]);
}
for (i = 0; i<5; i++)
{
for (j = 0; j<5; j++)
{
if (a[j]<a[i])
{
temp = a[i];
a[i] = a[j];
a[j] = temp;
}
}
}
printf("the result is : \n");
for (i = 0; i<5; i++)
{
printf("%g ", a[i]);
}
printf("\n");
{
printf("%g ", a[i]);
}
printf("\n");
while (1);
return 0;
}
return 0;
}
4、题目:求100以内的素数,全部打印出来
#include<stdio.h>
#include<stdio.h>
int main()
{
int i;
int j = 1;
{
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;
}
{
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;
}
例如: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;
}