文章目录
一 、将数组A中的内容和数组B中的内容进行交换。(数组一样大)
(1)、代码
#include<stdio.h>
int main(){
//定义两个数组,数组一样大
int arr1[] = { 1, 2, 3, 4, 5, 6, 7, 8, 9 };
int arr2[] = { 11, 12, 13, 14, 15, 16, 17, 18, 19 };
//进行内容交换
for (int i = 0; i < sizeof(arr1) / sizeof(int); i ++){
int temp = arr1[i];
arr1[i] = arr2[i];
arr2[i] = temp;
}
//打印出arr1的内容
for (int i = 0; i < sizeof(arr1) / sizeof(int); i++){
printf("%d ", arr1[i]);
}
printf("\n");
//打印出arr2的内容
for (int i = 0; i < sizeof(arr1) / sizeof(int); i++){
printf("%d ", arr2[i]);
}
printf("\n");
system("pause");
return 0;
}
(2)、结果
(3)、总结
交换两个数组的内容实质上是对每一个元素的交换。
二、计算1/1-1/2+1/3-1/4+1/5 …… + 1/99 - 1/100 的值。
(1)、代码
方法一:
#include<stdio.h>
//求倒数
double countDown(int n){
return 1 / (double)n;
}
int main(){
double result = 0;
for (int i = 1; i <= 100; i ++){
if (i % 2 == 0)
result -= countDown(i);
else
result += countDown(i);
}
printf("%lf",result);
system("pause");
return 0;
}
方法二:
#include<stdio.h>
#include<stdlib.h>
int main(){
double sum = 0;
double temp = 1;
int flag = 1;
for (int i = 1; i <= 100; i ++){
temp = flag * 1.0 / i;//1.0的目的是将int型转化为double
sum += temp;
flag *= -1;
}
printf("%lf\n",sum);
system("pause");
return 0;
}
(2)、结果
三、编写程序数一下 1到 100 的所有整数中出现多少次数字9。
(1)、代码
#include<stdio.h>
#include<stdlib.h>
int main(){
// 计数器
int count = 0;
for (int i = 0; i <= 100; i++){
//取个位数字
if (i % 10 == 9){
count += 1;
}
//取十位数字,
if (i / 10 == 9){
count ++;
}
}
printf("1到 100 的所有整数中共出现%d次数字9\n", count);
system("pause");
return 0;
}
(2)、结果
(3)、总结
数字分拆问题最常用的就是“%”和“/”,利用这两个运算就能够得到数字的每一位。