//1. 将数组A中的内容和数组B中的内容进行交换。(数组一样大)
//此题我们假设整形数组,类似于整形数交换,不一样的是我们需要定义一个变量来遍历整个数组,定义中间值来存储交换时的中间值
#include<stdio.h>
#define N 6 //定义一个数组的大小
int main() {
int temp1[N],temp2[N];
int temp3,i; //定义暂存值 temp3 定义变量i遍历数组
printf("输入数组temp1的内容:\n"); //输入
for(i=0;i<N;i++)
scanf("%d",&temp1[i]);
printf("输入数组temp2的内容:\n");
for(i=0;i<N;i++)
scanf("%d",&temp2[i]);
for(i=0;i<6;i++) { //交换
temp3=temp1[i];
temp1[i]=temp2[i];
temp2[i]=temp3;
}
printf("temp1数组的内容为:\n"); //输出
for(i=0;i<N;i++)printf("%d ",temp1[i]);
printf("\n");
printf("temp2数组的内容为:\n");
for(i=0;i<N;i++) printf("%d ",temp2[i]);
printf("\n");
return 0;
}
//2. 计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值。
//此题我们需要建立一个flag 标志位变量 在1和-1之间来回变换
#include<stdio.h>
#include<math.h>
int main() {
int i,s=-1; // 变量i为分母,s是一个标志位,先让他变为-1
double sum=0.0,t; //定义总和,定义一个分项式t,他存放的是每一项的值
for(i=1;i<=100;i++) {
s*=-1; //进入循环第一遍s=1;
t =s*(1.0/i); //标志位S不断和分项式做乘法,改变其正负
sum+=t; //累加总和
}
printf("总和sum结果为:%fl\n",sum);
return 0;
}
//3. 编写程序数一下 1到 100 的所有整数中出现多少次数字9。
//需要遍历整个数组1-100之间,我们只需要判断变量取模运算是否为9或变量除10是否为9即可
#include<stdio.h>
int main() {
int temp=0; //定义了暂存变量,初值为0,存取整数9的次数
int i;
for(i=1;i<=100;i++) { //遍历整数 1-100之间
if((i%10==9)temp++; //不光是尾数为9,当到90的时候十位数也为9,所以为或运算,还有一个99里面有两个9
if(i/10==9))temp++; //所以需要分开来写
}
printf("出现的9的次数为: %d ",temp);
return 0;
}
此题答案为20个,其实每一个数字在1-100之间都为20个
可以这样来记 9,19,29,39,49,59,69,79,89,99 10个 记录个位
90,91,92,93,94,95,96,97,98,99 10个 记录十位