2013年
9次循环!!! 我看菜鸟教程上是i = 10; i > 1; i --
sse上面也有类似的题, 出了中位数还有平均数, 众数. 主要是排序, 冒泡倍, 先从前往后再从后往前, flag可以省略.
用strcmp, strcpy
这题做了近10遍了.
这题出的挺好的, n最后算错了, abc应该从i = 0; i < 10; i ++
没难度, 注意从a[0][0] = 1开始, 不要从什么a[1][0], a[1][1]开始.
long double 要用%Lf L叫格式修饰符.
long用%ld
long long用%lld
int用%d
有些细节看苏小红的书
这题我也做过, 吃过亏. 比较好的方法是首先cnt = 1, 把i移到空格位置,
如果遇到"空格+字母"cnt++,
一定要注意只用for一个循环, 不要再在循环中套while那是不好的方法, 我吃过亏的方法.
这题说了区分大小写, 那就直接用strcmp.
做sse时还要求不区分大小写, 我当时就把大写全tolower后再strcmp.
// 这道题花近10, 错误其实也不多, 主要是/10 与 %10, index好像没有变化.
#include <stdio.h>
#include <stdlib.h>
#define SIZE 51
int BigFact(int m, int data[]);
int main()
{
int data[SIZE]; /* 存储50位数,为了方便记忆,不使用data[0] */
int index; /* 表示阶乘值的位数 */
int n;
int i, j;
printf("Input n:\n");
scanf("%d", &n);
for (i = 1; i <= n; i++)
{
index = BigFact(i, data);
if (index != 0)
{
printf("%d! = ", i);
for (j = index; j > 0; j--)
{
printf("%d", data[j]);
}
printf("\n");
}
else
{
printf("Over flow!\n");
exit(1);
}
}
return 0;
}
/*函数功能:计算m!,存于数组data中,若数组未溢出,则返回阶乘值的位数,否则返回0*/
int BigFact(int m, int data[])
{
int i;
int j, k;
int index = 1;
for (i = 0; i < SIZE; i++)
{
data[i] = 0;
}
data[1] = 1;
for (i = 1; i <= m; i++)
{
for (j = 1; j <= index; j++)
{
data[j] = data[j] * i;
}
for (k = 1; k < index; k++) //
{
if (data[k] >= 10)
{
data[k + 1] += data[k] / 10;
data[k] = data[k] % 10; //
}
}
while (data[index] >= 10 && index <= SIZE - 1)
{
data[index + 1] += data[index] / 10;
data[index] = data[index] % 10;
index++;
}
}
if (index <= SIZE)
{
return index;
}
else
{
return 0;
}
}