} }
int main() {
struct stu *s; int n,age;
printf(\scanf(\s = creatlist(n); display(s);
printf(\scanf(\deletelist(s,age); display(s); return 0; }
2、实现一个函数,把一个字符串中的字符从小写转为大写。
#include \#include \
void uppers(char *s,char *us) {
for(;*s!='\\0';s++,us++) {
if(*s>='a'&&*s<='z') *us = *s-32; else *us = *s; }
*us = '\\0'; }
int main() {
char *s,*us; char ss[20];
printf(\scanf(\s = ss; uppers(s,us);
printf(\getch(); }
随机输入一个数,判断它是不是对称数(回文数)(如3,121,12321,45254)。不能用字符串库函数
/*************************************************************** 1.
函数名称:Symmetry
功能: 判断一个数时候为回文数(121,35653) 输入: 长整型的数
输出: 若为回文数返回值为1 esle 0
******************************************************************/ unsigned char Symmetry (long n) {
long i,temp; i=n; temp=0;
while(i) //不用出现长度问题,将数按高低位掉换 {
temp=temp*10+i; i/=10; }
return(temp==n); } 方法一
/* --------------------------------------------------------------------------- 功能:
判断字符串是否为回文数字 实现:
先将字符串转换为正整数,再将正整数逆序组合为新的正整数,两数相同则为回文数字 输入:
char *s:待判断的字符串 输出: 无 返回:
0:正确;1:待判断的字符串为空;2:待判断的字符串不为数字; 3:字符串不为回文数字;4:待判断的字符串溢出
---------------------------------------------------------------------------- */ unsigned IsSymmetry(char *s) {
char *p = s; long nNumber = 0; long n = 0; long nTemp = 0;
/*判断输入是否为空*/ if (*s == \\'\\\\0\\') return 1;
/*将字符串转换为正整数*/ while (*p != \\'\\\\0\\') {
/*判断字符是否为数字*/ if (*p<\\'0\\' || *p>\\'9\\') return 2;
/*判断正整数是否溢出*/
if ((*p-\\'0\\') > (4294967295-(nNumber*10)))
return 4;
nNumber = (*p-\\'0\\') + (nNumber * 10); p++; }
/*将数字逆序组合,直接抄楼上高手的代码,莫怪,呵呵*/ n = nNumber; while(n) {
/*判断正整数是否溢出*/
if ((n) > (4294967295-(nTemp*10))) return 3;
nTemp = nTemp*10 + n; n /= 10; }
/*比较逆序数和原序数是否相等*/ if (nNumber != nTemp) return 3;
return 0; } 方法二
/* --------------------------------------------------------------------------- 功能:
判断字符串是否为回文数字 实现:
先得到字符串的长度,再依次比较字符串的对应位字符是否相同 输入:
char *s:待判断的字符串 输出: 无 返回:
0:正确;1:待判断的字符串为空;2:待判断的字符串不为数字; 3:字符串不为回文数字
---------------------------------------------------------------------------- */ unsigned IsSymmetry_2(char *s) {
char *p = s; int nLen = 0; int i = 0;
/*判断输入是否为空*/ if (*s == \\'\\\\0\\') return 1;
/*得到字符串长度*/ while (*p != \\'\\\\0\\') {
/*判断字符是否为数字*/ if (*p<\\'0\\' || *p>\\'9\\') return 2; nLen++; p++; }
/*长度不为奇数,不为回文数字*/ if (nLen%2 == 0) return 4;
/*长度为1,即为回文数字*/