关于C语言中strcpy的用法以及一个简单案例分析。

关于C语言中strcpy的用法以及一个简单案例分析。,第1张

你的复制是往后挪了一格的,字符数当然要 +1。

那一句没有起到任何实质性作用,因为 a[0]本来就是'a'。

strcpy(str,"1234"):

初始 str=="",strcpy 内部的指针(指示当前字符)指向"1234"中的'1'

第一步 str=="1"(复制了一个字符),指针往后挪一格('2')

第二步 str=="12"(又复制了一个),指针往后挪('3')

第三步 str=="123",指针往后挪('4')

第四步 str=="1234",指针往后挪('\0')

指针已经跑到字符串"1234"的末尾了,表示复制结束,退出。

结合这个思路理解一下 strcpy(&a[1],a) 复制的结果。

puts(char* str)本来传的参就是个地址,你给它个指针,它根据指针指向的内存找到一串字符(当然要以'\0'结尾)输出出去。

C语言输出水仙花数的具体分析和实现流程如下:

1、水仙花数的含义

“水仙花数”是一个三位数其各位数字的立方和等于该数本身。例如:3^3 + 7^3+ 0^3 = 370

2、算法分析

把给出的某个三位数的个位、十位、百位分别拆分,并求其立方和(设为sum),若sum与给出的三位数相等, 则为“水仙花数”。

3、算法设计

“水仙花数”是一个三位数,可以确定该数的取值范围是 100〜999。对应的循环条件如下:

for (n=10n<1000n++) {}

将n整除以100,得出n在百位上的数字h。

将(n-i*100)整除以10, 得出n在十位上的数字t。

将n对10取余,得出n在个位上的数字a。

求得h,t,a 三个数字的立方和是否与n相等,如果相等则证明该数为水仙花数。

4、代码实现

#include <stdio.h>

int main() {

int h, t, a, n

printf("result is:")

for ( n=100n<1000n++ )  { /*整数的取值范围*/

h = n / 100

t = (n-h*100) / 10

a = n % 10

if (n == h*h*h + t*t*t + a*a*a)  /*各位上的立方和是否与原数n相等*/

printf("%d  ", n)}

printf("\n")

return 0}

扩展资料:

常见水仙花数

水仙花数又称阿姆斯特朗数。

1、三位的水仙花数共有4个:153,370,371,407;

2、四位的四叶玫瑰数共有3个:1634,8208,9474;

3、五位的五角星数共有3个:54748,92727,93084;

4、六位的六合数只有1个:548834;

5、七位的北斗七星数共有4个:1741725,4210818,9800817,9926315;

6、八位的八仙数共有3个:24678050,24678051,88593477

参考资料来源:百度百科-水仙花数


欢迎分享,转载请注明来源:内存溢出

原文地址:https://54852.com/yw/11083589.html

(0)
打赏 微信扫一扫微信扫一扫 支付宝扫一扫支付宝扫一扫
上一篇 2023-05-13
下一篇2023-05-13

发表评论

登录后才能评论

评论列表(0条)

    保存