练习二
1、输入一个正整数将其转化为二进制并输出。(使用数组存储二进制的每一位)
#include<stdio.h>
int main(void) {
int num = 0, i, j, a[100];
scanf("%d", &num);
for (i = 0; 1; i++) {
if (num == 1) {
a[i] = 1;
break;
}
a[i] = num % 2;
num /= 2;
}
for (j = i; j > -1; j--) {
printf("%d", a[j]);
}
}
2、输入年月日,判断这天是该年份的第几天。
#include<stdio.h>
int main(void) {
int year, month, day, i, count = 0, a[12] = {31, 28, 31, 30, 31, 30, 31, 31, 30, 31, 30, 31};
printf("请输入年:\n");
scanf("%d", &year);
printf("请输入月:\n");
scanf("%d", &month);
printf("请输入日:\n");
scanf("%d", &day);
if(year % 400 == 0 || (year % 4 == 0 && year % 100 != 0)) {
a[1] = 29;
}
for (i = 0; i < month - 1; i++) {
count += a[i];
}
count += day;
printf("%d", count);
}
3、从大到小排序(冒泡法)
#include<stdio.h>
int main(void) {
int a[4], i, j, temp;
for (i = 0; i < 4; i++) {
scanf("%d", &a[i]);
}
for (i = 0; i < 3; i++) {
for (j = 0; j < 3; j++) {
if (a[j] < a[j + 1]) {
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
for (i = 0; i < 4; i++) {
printf("%d\t", a[i]);
}
}
4、打印水仙花数
#include<stdio.h>
int main(void) {
int i, j, s , k;
for(s =100; s < 1000; s++) {
i = s / 100;
j = s / 10 - i * 10;
k = s % 10;
if(s == i * i * i + j * j * j + k * k * k ) {
printf("%d\n", s);
}
}
printf("\n");
return;
}
5、任意输入10个整数的数列,先将整数按照从大到小的顺序进行排序,然后输入一个整数插入到数列中,使数列保持从大到小的顺序。
#include<stdio.h>
void mop(int n, int a[]) {
int i, j, temp;
for (i = 0; i < n; i++) {
for (j = 0; j < n - i; j++) {
if (a[j] < a[j + 1]) {
temp = a[j];
a[j] = a[j + 1];
a[j + 1] = temp;
}
}
}
for (i = 0; i < n + 1; i++) {
printf("%d\t", a[i]);
}
}
int main(void) {
int a[5], i, temp;
for (i = 0; i < 4; i++) {
scanf("%d", &a[i]);
}
mop(3, a);
printf("\n");
scanf("%d", &temp);
printf("\n");
a[4] = temp;
mop(4, a);
}