1、统计混合汉字与ASCII字符串字符数量
2、汉字逆置
3、求水仙花数
4、字符转整数
#include <stdio.h>
//统计混合汉字与ASCII字符串字符数量
int main()
{
char buf[100]="你好abc";
int len = 0;
int i = 0;
while (buf[i])
{
if(buf[i] < 0)
i++;
i++;
len++;
}
printf("%d\n",len);
return 0;
}
/*char buf[100]="你";
printf("%d\n",buf[0]);-------(-60)
printf("\n%d\n",buf[1]);-----(-29)
汉字的两位字节ASCII值均为负数*/
#include <stdio.h>
//汉字逆置
int main()
{
char buf[100]="你好世界";//GBK 编码的汉字
int len=0;
while (buf[len++]);
len--;
printf("%d\n",len);//一个汉字两个字节
int min=0;
int max=len-1;
while (min < max)
{
char temp = buf[min];
buf[min] = buf[max - 1];
buf[max - 1] = temp;
temp = buf[min + 1];
buf[min + 1] = buf[max];
buf[max] = temp;
min += 2;
max -= 2;
}
printf("%s\n",buf);
return 0;
}
//水仙花数:一个n(n>2)位数,它的每个位上的数字的n次幂的和,
//等于这个数本身
#include <stdio.h>
int main()
{
for(int i = 100; i < 1000; i++ )
{
int a = i / 100;
int b = (i % 100) / 10;
int c = i % 10;
if(i == a*a*a + b*b*b + c*c*c)//特注:判断等于为==,赋值为=
printf("%d\n",i);
}
return 0;
}
#include <stdio.h>
//字符转整数
int main(){
char buf[100] = "1234";
int len = 0;
while (buf[len++]);
len--;
int value = 0;
int i;
int temp = len;
for(i = 0; i < len; i++){
int base = 10;
if ((temp - i - 1) == 0)//最后一位数(个位)
base = 1;
else {
int j;
for(j = 1; j < (temp - i - 1); j++)
base *= 10;
}
value += (base * (buf[i] - '0'));
}
printf("%d\n",value);
return 0;
}