目录
- 1.十进制数转换二进制数
- 实例代码
- 程序分析
- 2.判断某一年是否为闰年
- 实例代码
- 程序分析
- 3.使用*打印平行四边形
- 实例代码
- 程序分析
- 4.在控制台打印出著名的杨辉三角
- 实例代码
- 程序分析
- 5.实现投票统计功能
- 实例代码
- 程序分析
- 6.交换数组中最大数和最小数的位置
- 实例代码
- 程序分析
- 7.反转字符串
- 实例代码
- 程序分析
- 8.使用goto语句从循环中跳出
- 实例代码
- 程序分析
- 9.计算字符串中单词的个数
- 实例代码
- 程序分析
- 10.控制台打印系统的日期和时间
- 实例代码
- 程序分析
- 11.将3个数由大到小的顺序输出
- 实例代码
- 程序分析
- 12.模拟用户名登陆
- 实例代码
- 程序分析
1.十进制数转换二进制数
实例代码
//
#include "stdio.h"
int main(){
int m, n, k;//定义变量
int a[] = { 0 };
printf("请输入一个~32767之间的数字:\n");
scanf("%d", &n);
printf("十进制数%d转换为二进制数是:\n", n);
for (int i =; i < 15; ++i) {//for循环从0-14,最高位为符号位,本例始终为0
m = n %;//取2的余数
k = n /;//取被2整除的结果
n = k;
a[i] = m;//将余数存入数组a数组中
}
for (int i =; i >=0 ; i--) {//for循环将数组中的16个元素从后往前输出
printf("%d", a[i]);
if (i % == 0) {//每输出4个元素,输出一个空格
printf(" ");
}
}
}
运行结果:
程序分析
本实例比较简单,而且注释也比较详细,这里需要注意的是第二个for循环是从后往前输出15~0,因为第一个for循环对2取余的结果存入数组时是从a[0]开始存储的。
2.判断某一年是否为闰年
实例代码
//
// Created by 冲哥 on/9/7.
//
#include "stdio.h"
int main(){
int year;//定义整形变量year
printf("请输入要查询的年份:\n");
scanf("%d", &year);//从键盘输入要查询的年份
if ((year % == 0 && year % 100 !=0) || year % 400 == 0) {//判断是否为闰年的条件
printf("%d年这一年是闰年\n", year);
} else {
printf("%d年这一年不是闰年\n", year);
}
}
运行结果:
程序分析
今天分享的也是一个入门级实例,从键盘输入一个表示年份的整数,判断该年份是否为闰年。该实例的要点就是判断闰年的算法:(year % 4 == 0 && year % 100 !=0) || year % 400 == 0
3.使用*打印平行四边形
实例代码
//
#include "stdio.h"
int main(){
char arr[] = {'*','*','*','*','*'};
for (int i =; i < 5; i++) {//输出5行
for (int j =; j <= i; j++) {
printf(" ");//输出空格的数量随着行数的变化而变化
}
for (int k =; k < 5; k++) {
printf("%c", arr[k]);//输出数组中的元素
}
printf("\n");//输出一行后换行
}
}
运行结果:
程序分析
本实例的要点就是理解三个for循环
第一个for循环控制整个图形的行数,本实例中的图形共5行,所以i的范围为0~4。
第二个for循环用来控制空格的数量。
第三个for循环用将数组a中的元素逐个输出。
4.在控制台打印出著名的杨辉三角
实例代码
//
#include "stdio.h"
int main(){
int a[][8]={0};//初始化数组(本实例打印8行)
for (int i =; i < 8; i++) {//for循环定义每行的第一个数和对角线上的数,数值为1
a[i][i] =;
a[i][] = 1;
}
for (int k =; k < 8; k++) {
for (int j =; j < k; j++) {//用两个for循环实现除对角线和每行第一个元素外其他元素的赋值
a[k][j] = a[k-][j-1] + a[k-1][j];
}
}
for (int i =; i < 8; i++) {
for (int j =; j <= i; j++) {//两个for循环将数组a中的所有元素输出
printf("%d\t", a[i][j]);
}
printf("\n");
}
}
程序分析
首先要分析杨辉三角的特点,找出规律:
处理每行第一个数和对角线上的数都是1意外,其它的数就是前一行相邻的两数之和。找到这个规律,就可以很轻松的用for循环实现了。
5.实现投票统计功能
实例代码
//实现功能:某次选举,共有个候选人,
//输入参加选举的人数及每个人选举的内容,输出个候选人最终的得票数及无效选票数
//
#include "stdio.h"
int main(){
int NO = 0;
int NO = 0;
int NO = 0;
int b =;
int n, a[];
printf("请输入参加选举的人数:\n");//最大
scanf("%d", &n);
printf("请给候选人投票,或2或3\n");
for (int i =; i < n; i++) {
scanf("%d", &a[i]);
}
for (int i =; i < n; i++) {
if (a[i] ==) {
NO++;
}
else if (a[i] ==) {
NO++;
} else if (a[i] ==) {
NO++;
} else {
b++;
}
}
printf("投票结果如下:\n");
printf("一号选手:%d票\n二号选手:%d票\n三号选手:%d票\n无效票数:%d\n", NO, NO2, NO3, b);
}
运行结果:
程序分析
输入参加选举的人数,再输入每个人的选举内容并将其存入数组中。对存入数组中的元素进行判断,统计出各个候选人的票数和无效的票数。
6.交换数组中最大数和最小数的位置
实例代码
//
//实现功能:交换数组中最大数和最小数的位置
//
#include "stdio.h"
int main(){
int a[];
int max, min;
int m, n;
printf("请输入个数字:\n");
for (int i =; i < 10; i++) {
scanf("%d", &a[i]);
}
printf("输入的个数是:\n");
for (int i =; i < 10; i++) {
printf("%d", a[i]);
}
printf("\n");
max = a[];
for (int i =; i < 10; i++) {
if (a[i] > max) {
max = a[i];
m = i;
}
}
min = a[];
for (int i =; i < 10; i++) {
if (a[i] < min) {
min = a[i];
n = i;
}
}
a[m] = min;
a[n] = max;
printf("交换最大数和最小数的位置后:\n");
for (int i =; i < 10; i++) {
printf("%d", a[i]);
}
} //
// Created by 冲哥 on/9/13.
//实现功能:交换数组中最大数和最小数的位置
//
#include "stdio.h"
int main(){
int a[];//定义数组
int max, min;//定义最大值和最小值
int m, n;//定义最大值和最小值的位置
printf("请输入个数字:\n");
for (int i =; i < 10; i++) {
scanf("%d", &a[i]);
}
printf("输入的个数是:\n");
for (int i =; i < 10; i++) {
printf("%d", a[i]);
}
printf("\n");
max = a[];
for (int i =; i < 10; i++) {
if (a[i] > max) {
max = a[i];//找最大值
m = i;
}
}
min = a[];
for (int i =; i < 10; i++) {
if (a[i] < min) {
min = a[i];//找最小值
n = i;
}
}
a[m] = min;
a[n] = max;
printf("交换最大数和最小数的位置后:\n");
for (int i =; i < 10; i++) {
printf("%d", a[i]);
}
}//
// Created by 冲哥 on/9/13.
//实现功能:交换数组中最大数和最小数的位置
//
#include "stdio.h"
int main(){
int a[];//定义数组
int max, min;//定义最大值和最小值
int m, n;//定义最大值和最小值的位置
printf("请输入个数字:\n");
for (int i =; i < 10; i++) {
scanf("%d", &a[i]);
}
printf("输入的个数是:\n");
for (int i =; i < 10; i++) {
printf("%d", a[i]);
}
printf("\n");
max = a[];
for (int i =; i < 10; i++) {
if (a[i] > max) {
max = a[i];//找最大值
m = i;
}
}
min = a[];
for (int i =; i < 10; i++) {
if (a[i] < min) {
min = a[i];//找最小值
n = i;
}
}
a[m] = min;
a[n] = max;
printf("交换最大数和最小数的位置后:\n");
for (int i =; i < 10; i++) {
printf("%d", a[i]);
}
}
运行结果:
程序分析
首先找到数组中的最大值和最小值,记录它们的位置,然后交换位置,最后将交换后的数组输出。
7.反转字符串
实例代码
//
//实现功能:输入一个字符串,然后将该字符串反向输出
//
#include "stdio.h"
#include "string.h"
#define N
void convert_str(char str[N]);
void convert_str(char str[N]){
int j;
char temp;
for (int i =; i < strlen(str)/2; i++) {
j = strlen(str) -;
temp = str[i];
str[i] = str[j - i];
str[j - i] = temp;
}
printf("反向输出:%s", str);
}
int main(){
char str[N];
printf("请输入字符串:\n");
gets_s(str, N);
printf("输入的字符串为:%s\n", str);
convert_str(str);
}
运行结果:
程序分析
注意:实例中有这样一个语句j = strlen(str) - 1;这里j为什么是j = strlen(str) - 1;而不是strlen(str)呢?原因如下:如果数组s中含有10个元素,那么它的长度为10,而s的数组下标从0开始那么下标的最大值为9,j这里是代表数组下标,所以开始时的最大值应是strlen(str)-1也就是9。
8.使用goto语句从循环中跳出
实例代码
//
// Created by 冲哥 on/9/15.
//实现功能:使用goto语句从循环中跳出
//
#include "stdio.h"
#define EXIT
void show_Menu(){
printf("菜单选项:\t");
printf(":显示\t");
printf(":添加\t");
printf(":查询\t");
printf(":删除\t");
printf(":退出\n");
}
int main(){
int num;
show_Menu();
for (int i =; i < 10; i++) {
printf("第%d此循环\n", i);
do {
printf("请输入菜单选项:\n");
scanf("%d", &num);
if (num == EXIT){
goto exit;
}
printf("****************菜单功能部分****************\n");
} while (num <);
}
exit:
printf("程序退出!\n");
return;
}
运行结果:
程序分析
goto语句后面会有一个标识符goto exit;当程序满足goto条件时,程序就会直接跳转到标识符位置。
9.计算字符串中单词的个数
实例代码
//
//实现功能:计算字符串中单词的个数
//
#include "stdio.h"
#define LEN
int main(){
char str[LEN];
int index;
char blank;
int words =;
printf("请输入字符串:\n");
gets_s(str, LEN);
if (str[] == '\0') {
printf("输入的字符串为空\n");
} else if (str[] == ' ') {
printf("输入的字符串的第一个字符是空格\n");
} else {
for (int i =; str[i] != '\0'; ++i) {
blank = str[i];
if (blank == ' ') {
words++;
}
}
printf("输入的字符串中有%d个单词\n", words);
}
}
运行结果:
程序分析
用for循环遍历字符数组,然后判断是不是结尾\0,如果不是,就判断是不是空格,是空格的话,单词数加1.
10.控制台打印系统的日期和时间
实例代码
//
//实现功能:控制台打印系统的日期和时间
//
#include "stdio.h"
#include "time.h"
int main(){
struct tm *sysTime;//定义结构体,用于存放日期和时间
time_t sysDay;
time(&sysDay);//获取系统日期
sysTime = localtime(&sysDay);//转换为系统日期
printf("系统日期:%d-%d-%d\n", + sysTime->tm_year, sysTime->tm_mon + 1, sysTime->tm_mday);
printf("系统时间:%d:%d:%d\n", sysTime->tm_hour, sysTime->tm_min, sysTime->tm_sec);
return;
}
运行结果:
程序分析
本实例主要掌握系统日期和时间的获取方法。
11.将3个数由大到小的顺序输出
实例代码
//
//实现功能:输入三个整数,然后按由大到小的顺序输出
//
#include "stdio.h"
void swap(int *pa, int *pb){
int temp;
temp = *pa;
*pa = *pb;
*pb = temp;
}
void compare(int *pa, int *pb, int *pc){
if (*pa < *pb) {
swap(pa, pb);
}
if (*pa < *pc) {
swap(pa, pc);
}
if (*pb, *pc) {
swap(pb, pc);
}
}
int main(){
int a, b, c, *pa, *pb, *pc;
printf("请输入三个数:\n");
scanf("%d%d%d", &a, &b, &c);
pa = &a;
pb = &b;
pc = &c;
compare(pa, pb, pc);
printf("%d\t%d\t%d\n", a, b, c);
return;
}
运行结果
程序分析
还记不记得之前讲过的传址和传值,这里就用到了传址。
12.模拟用户名登陆
实例代码
//
//实现功能:模拟用户名登陆
#include "stdio.h"
#include "string.h"
int main(){
char user_name[] = {"zhangsan"};
char password[]={"123456"};
char name[], pwd[20];
int i =;
while (i <) {
printf("请输入用户名:\n");
gets_s(name,);
printf("请输入密码:\n");
gets_s(pwd,);
if (strcmp(user_name, name) !=) {
printf("您好,您输入的用户名有误!请重新输入:\n");
} else {
if (strcmp(password, pwd) !=) {
printf("您好,您输入的密码有误!请重新输入:\n");
} else {
printf("欢迎使用!\n");
break;
}
}
i++;
}
if (i ==) {
printf("输入错误已达次,账号被锁定!\n");
}
}
运行结果
正常系
D:\Users\source\C\Test0823\cmake-build-debug\Test0823.exe
请输入用户名:
zhangsan
请输入密码:
123456
欢迎使用!
Process finished with exit code 0
异常系
D:\Users\source\C\Test0823\cmake-build-debug\Test0823.exe
请输入用户名:
zhang
请输入密码:
123456
您好,您输入的用户名有误!请重新输入:
请输入用户名:
zhangsan
请输入密码:
1234
您好,您输入的密码有误!请重新输入:
请输入用户名:
zhangs
请输入密码:
123
您好,您输入的用户名有误!请重新输入:
输入错误已达3次,账号被锁定!
Process finished with exit code 0
程序分析
本实例中使用到了字符串的比较函数strcmp(str1, str2);,这个函数的功能是按照ASCII码顺序比较两个字符串,并由返回值返回比较结果。
str1 = str2 返回值为0
str1 > str2 返回值大于0
str1 < str2 返回值小于0