练习(一)
1.有1、2、3、4个数字,能组成多少个互不相同且无重复数字的三位数?都是多少?(使用数组)
#include<stdio.h>
int main(void) {
int a [] = {1, 2, 3, 4};
int i, j, k, s =0;
for(i = 0; i < 4; i++) {
for(j = 0; j < 4; j++) {
if(i == j) {
continue;
}
for(k = 0; k < 4; k++) {
if(k == i || k == j) {
continue;
}
s++;
printf("%d %d %d\t", a[i], a[j], a[k]);
}
}
}
printf("%d\n", s);
}
2.有一个长度为10的数组{12,52,64,33,10,32,53,88,2,90},根据下标将其中某个元素值改为0,将该元素放在数组的最后,并打印数组的每个元素。
#include<stdio.h>
int main(void) {
int a[] = {12, 52, 64, 33, 10, 32, 53, 88, 2, 90};
int num = 0, i, j = 0;
scanf("%d", &num);
for (i = 0; i < 10; i++) {
if (i == 9) {
a[i] = 0;
break;
}
if (i >= num) {
j = i + 1;
a[i] = a[j];
}
}
for (i = 0; i < 10; i++) {
printf("%d\t", a[i]);
}
}
3、函数的递归
#include<stdio.h>
void judge();
int main(void) {
judge();
printf("111");
}
void judge() {
int d = 0;
printf("请重新输入:\n");
scanf("%d", &d);
if (d != 0) {
judge();
}
printf("成功了,因为打的是:%d\n", d);
}
4、函数返回类型
#include<stdio.h>
int func1();
int func2();
int func3();
int main(void) {
int i = 0;
printf("%d\n", func1());
printf("%d\n", func2());
printf("%d", i = i + 1);
}
int func1() {
int i = 1;
return i += 1;
}
int func2() {
int i = 1;
return i + 1;
}
int func3() {
int i = 1;
return i = i + 1;
}
5、作用域
#include<stdio.h>
int func(int a);
int y = 0;
int main(void) {
int x = 0;
y = func(x);
//printf("%d", b);
//return -1;
printf("1111~~~\n");
printf("%d", y);
}
int func(int b) {
printf("%d", b);
//printf("%d", x);
return 1;
printf("hahha\n");
}
多加练习,才能熟练掌握!