本次练习包括一维数组(含字符型数组)的相关知识,建议学习一维数组后做下面练习,如果可以独立完成下面习题的80%,证明你已经比较熟练的掌握相关语法,可以向函数及指针部分进军了,如果没能顺利完成,请参看相关程序,参考程序系本人所写,难免有纰漏之处,有任何疑问敬请留言。
题目目录如下:
登录验证
用户邮箱格式验证
判断平年/闰年
自定义金字塔
计算器
冒泡法排序
1、登录验证
要求:模拟用户登录过程,验证用户名、密码和校验码,如果全部正确提示用户登录成功,否则,提示用户相关输入错误。
目的:掌握登录校验的规则和原理。
2、用户邮箱格式验证
要求:用户输入邮箱,验证邮箱格式是否正确(验证用户输入的邮箱地址中是否含有字符‘@‘)。
目的:掌握邮箱验证控件的原理和方法。
3、判断平年/闰年
要求:用户输入年份之后,判断输入的是平年还是闰年。
目的:掌握if判断的方法。
4、自定义金字塔
要求:打印以下图形。
图形一
*
**
***
****
*****
图形二
*******
*****
***
*
5、计算器
要求:可以完成加、减、乘、除和取余的计算。
目的:灵活掌握switch分支。
6、冒泡法排序
要求:输入六个学生成绩,然后排序。
目的:掌握排序的基本方法,熟悉数组。
参考程序:
1、登录验证
#include
<stdio.h>
#include <stdlib.h>
#include
<string.h>
int main(void)
{
char username[20];
char password[20];
char checkCode[5];
printf("请输入用户名:");
scanf("%s", username);
printf("请输入密码:");
scanf("%s", password);
printf("请输入验证码:(1234)");
scanf("%s",
checkCode);
if(!strcmp(checkCode, "1234"))
{
if(!strcmp(username,"yuanchunxu")&&!strcmp(password, "123456"))
{
printf("成功登录!\n");
}
else
{
printf("用户名密码错误!\n");
}
}
else
{
printf("验证码错误!\n");
}
system("pause");
return 0;
}
2、用户邮箱格式验证
方法一:
#include
<stdio.h>
#include <stdlib.h>
#include
<string.h>
int main(void)
{
char email[20];
int
flag = 0;
int i = 0;
printf("请输入邮箱地址:");
//scanf和gets之间的主要区别在于scanf把空格、制表符、回车等都当作默认的结束符,而gets之把回车当作默认的结束符。
scanf("%s", email);
//gets(email);
//逐一判断,比较,看有没有‘@‘符号
for(i = 0; i < strlen(email); i++)
{
if(‘@‘ ==
email[i])
{
flag = 1;
break;
//system("pause");
//return 0;
}
}
if(0 == flag)
{
printf("非法\n");
}
else
{
printf("合法\n");
}
system("pause");
return 0;
}
方法二:
#include
<stdio.h>
#include <stdlib.h>
int main(void)
{
char email[20];
int flag = 0; //标志位的方法,在很多程序中可用
int i =
0;
printf("请输入邮箱地址:");
//scanf("%s", email);
gets(email);
while(email[i]!=‘\0‘)
{
if(‘@‘ ==
email[i])
{
//发现合法,设置标志位
flag =
1;
break;
}
i++;
}
//检验标志位,并根据标志位的不同,做出不同的处理
if(0 == flag)
{
printf("非法\n");
}
else
{
printf("合法\n");
}
system("pause");
return
0;
}
3、判断平年/闰年
#include <stdio.h>
#include
<stdlib.h>
int main(void)
{
int year = 0;
printf("请输入一个年份:");
scanf("%d", &year);
if(0 == year %
4)
{
if(0 == year % 100 )
{
if(0 ==
year % 400)
{
printf("%d是闰年\n",
year);
}
else
{
printf("%d是平年\n", year);
}
}
else
{
printf("%d是闰年\n",
year);
}
}
else
{
printf("%d是平年\n",
year);
}
system("pause");
return
0;
}
4、自定义金字塔
图案一:
#include <stdio.h>
#include
<stdlib.h>
int main(void)
{
int i = 1;
int j =
1;
//循环次数决定行数
for(i = 0; i < 5; i++)
{
//循环次数决定列数
for(j=0; j <= i; j++)
{
printf("*");
}
printf("\n");
}
system("pause");
return 0;
}
图案二:
#include
<stdio.h>
#include <stdlib.h>
int main(void)
{
int i = 0;
int k = 0;
//循环次数决定行数
for(i = 0; i < 4;
i++)
{
//循环次数决定列数
for(k = 0; k <= 7 - 2 * i;
k++)
{
printf("*");
}
printf("\n");
}
system("pause");
return
0;
}
5、计算器
#include <stdio.h>
#include
<stdlib.h>
int main(void)
{
int num1 = 0;
int num2
= 0;
int result = 0;
char opr;
int flag=0;
printf("input operator:");
scanf("%c",&opr);
//用户只有正确的输入程序才能够退出while循环,这种方法可以迫使用户按规定的法则输入
do
{
printf("请输入两个数值:");
flag = scanf("%d,%d",
&num1,&num2);
fflush(stdin); //清空输入缓存
//rewind(stdin); //这是清空输入缓存的另一种有效的方法,原理不同,但效果一样
}while(0 ==
flag);
switch(opr)
{
case ‘+‘:result=num1 + num2;
break;
case ‘-‘:result=num1 - num2; break;
case ‘*‘:result=num1 *
num2; break;
case ‘/‘:
if(0 == num2)
{
printf("除数不能为零\n");
system("pause");
return
0;
}
else
{
result=num1 /
num2;
}
break;
case ‘%‘:
if(0 ==
num2)
{
printf("除数不能为零\n");
system("pause");
return 0;
}
else
{
result=num1 % num2;
}
break;
default:printf("input wrong!");
}
printf("%d%c%d=%d\n",num1,opr,num2,result);
system("pause");
return 0;
}
6、冒泡法排序
#include <stdio.h>
#include
<stdlib.h>
#define COUNT 6
int main(void)
{
int
score[COUNT] = {0};
int i = 0;
int k = 0;
int flag =
0;
for(i = 0 ; i < COUNT ; i++)
{
//用户输入不合法就必须重新输入
do
{
printf("当前输入第%d成绩",
i);
flag=scanf("%d", &score[i]);
fflush(stdin);
}while(0 == flag);
}
//遍历数组排序前的所有元素
for(i = 0 ; i < COUNT ; i++)
{
printf("score[%d] = %d\n", i, score[i]);
}
//kernal
//第一重循环是总共冒泡的次数
//第二重循环是每次冒泡需要比较的次数
for(i = 0 ; i
< COUNT - 1 ; i++)
{
for(k = 0 ; k < COUNT - 1 - i ;
k++)
{
if(score[k] < score[k + 1])
{
//swap 典型的交换程序
int temp = 0;
temp = score[k];
score[k] = score[k+1];
score[k+1] = temp;
}
}
}
printf("\n------------------------------------\n");
//排序结束后,遍历数组中所有元素,有利于程序的对比
for(i = 0 ; i < COUNT ; i++)
{
printf("score[%d] = %d\n", i, score[i]);
}
system("pause");
return 0;
}
本文出自 “8403723” 博客,请务必保留此出处http://8413723.blog.51cto.com/8403723/1716115
原文地址:http://8413723.blog.51cto.com/8403723/1716115