1.交换两个相同大小的数组的值
#define _CRT_SECURE_NO_WARNINGS
#include<stdio.h>
#include<stdlib.h>
int main()
{
int a[4], b[4],i,temp;
printf("请为数组a赋值:\n");
for (i = 0; i < 4; i++)//创建数组a
{
scanf("%d",&a[i]);
}
printf("请为数组b赋值:\n");
for (i = 0; i < 4; i++)//创建数组b
{
scanf("%d", &b[i]);
}
//进行交换操作
for (i = 0; i < 4; i++)
{
temp = a[i];
a[i] = b[i];
b[i] = temp;
}
printf("输出交换后的a数组:\n");
for (i = 0; i < 4; i++)
{
printf("%d", a[i]);
}
printf("输出交换后的b数组:\n");
for (i = 0; i < 4; i++)
{
printf("%d", b[i]);
}
system("pause");
return 0;
}
在这里,数组交换值的过程可以练习到之前两个整形变量值的交换问题。有三种方法解决:
1.创建临时变量
2.不创建临时变量,利用两个变量之间的代数运算
3不创建临时变量,利用两个变量的二进制按位异或运算
2.计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值。
(1)直接计算
#include<stdio.h>
#include<stdlib.h>
void main()
{
double sum=0,i, j;//使用double类型的变量、否则使用int型,1/i的值便会是0
i = 1; j = 1;
while (i < 101)
{
sum = sum + j * (1 / i);
j = -j;//实现正负交替
i++;
}
printf("%f",sum);
system("pause");
}
在这里,正负号的交叉使用了新建变量来实现。当然,也可以考虑用(-1)的幂次来控制。就要使用到指数函数:pow(i,j)。即i的j次方。
(2)间接求和
由于第奇数个数前的系数是+1;第偶数个数前的系数为-1;
分别求出奇数个的和与偶数个的和,最终结果则是奇数个 与偶数个之和。
#include<stdio.h>
#include<stdlib.h>
void main()
{
double sum1, sum2, sum,i;
sum1 = sum2 = sum = 0;
for (i=1;i<100;i+=2)//奇数个的和
{
sum1 = sum1 + 1 / i;
}
for (i = 2; i < 101; i += 2)//偶数个的和
{
sum2 = sum2 - 1 / i;
}
sum = sum1 + sum2;
printf("%f", sum);
system("pause");
}
3.计算1~100中数字9 的出现次数
#include<stdio.h>
#include<stdlib.h>
int main()
{
int temp,count=0;//count用来计数
for (int i = 1; i < 100; i++)
{
temp = i;
if (temp == 9)//如果它等于9,就让计数器count+1;
{
count++;
}
//i>10的情况,提取出每一位进行比较
else if(temp%10==9)//提取个位
{
count++;
}
temp = temp / 10;//提取十位
if (temp == 9)
{
count++;
}
}
printf("%d\n", count);
system("pause");
return 0;
}