小白笔记-------------------------leetcode(258. Add Digits )
2016-11-23 10:37
561 查看
Given a non-negative integer
For example:
Given
Follow up:
Could you do it without any loop/recursion in O(1) runtime?
自己寻思了半天,结果发现别人的直接两行出来,惊叹之余,果断用了别人的方法,在这里总结两个函数
1、sprintf
format:格式化字符串。
[argument]...:可选参数,可以是任何类型的数据。
2、sscanf
函数原型:
int sscanf( const
char *, const char *, ...);
int sscanf(const char *buffer,const char *format,[argument ]...);
buffer存储的数据
format格式控制字符串
argument 选择性设定字符串
sscanf会从buffer里读进数据,依照format的格式将数据写入到argument里。
#include<stdio.h> 或者
#include <cstdio>
成功则返回参数数目,失败则返回-1,错误原因存于errno中。
经多次测试[来源请求],在linux系统中成功返回的是成功转换的值的个数,例如:
sscanf("1 2 3","%d %d %d",buf1, buf2, buf3); 成功调用返回值为3,即buf1,buf2,buf3均成功转换。
sscanf("1 2","%d %d %d",buf1, buf2, buf3); 成功调用返回值为2,即只有buf1,buf2成功转换。
代码如下:
int addDigits(int num) {
while(num>=10){
num = (num/10)+num%10;
}
return num;
}
num, repeatedly add all its digits until the result has only one digit.
For example:
Given
num = 38, the process is like:
3 + 8 = 11,
1 + 1 = 2. Since
2has only one digit, return it.
Follow up:
Could you do it without any loop/recursion in O(1) runtime?
自己寻思了半天,结果发现别人的直接两行出来,惊叹之余,果断用了别人的方法,在这里总结两个函数
1、sprintf
功能
把格式化的数据写入某个字符串缓冲区。头文件
stdio.h原型
int sprintf( char *buffer, const char *format, [ argument] … );参数列表
buffer:char型指针,指向将要写入的字符串的缓冲区。format:格式化字符串。
[argument]...:可选参数,可以是任何类型的数据。
返回值
返回写入buffer 的字符数,出错则返回-1. 如果 buffer 或 format 是空指针,且不出错而继续,函数将返回-1,并且 errno 会被设置为 EINVAL。2、sscanf
函数原型:
int sscanf( const
char *, const char *, ...);
int sscanf(const char *buffer,const char *format,[argument ]...);
buffer存储的数据
format格式控制字符串
argument 选择性设定字符串
sscanf会从buffer里读进数据,依照format的格式将数据写入到argument里。
头文件
编辑#include<stdio.h> 或者
#include <cstdio>
返回值
编辑成功则返回参数数目,失败则返回-1,错误原因存于errno中。
经多次测试[来源请求],在linux系统中成功返回的是成功转换的值的个数,例如:
sscanf("1 2 3","%d %d %d",buf1, buf2, buf3); 成功调用返回值为3,即buf1,buf2,buf3均成功转换。
sscanf("1 2","%d %d %d",buf1, buf2, buf3); 成功调用返回值为2,即只有buf1,buf2成功转换。
代码如下:
int addDigits(int num) {
while(num>=10){
num = (num/10)+num%10;
}
return num;
}
相关文章推荐
- 小白笔记---------------------leetcode( 453. Minimum Moves to Equal Array Elements )
- 小白笔记------------------------------------leetcode(389. Find the Difference )
- 小白笔记-----------------------------leetcode53. Maximum Subarray
- 小白笔记----------------------------------------leetcode(39. Combination Sum )
- 小白笔记--------------------------leetcode 34. Search for a Range
- 小白笔记------------leetcode(204. Count Primeszhe)
- 小白笔记---------------------------------leetcode(67. Add Binary )
- 小白笔记----------------------leetcode(100 Same Tree)
- 小白笔记--------------------------leetcode(20. Valid Parentheses )
- 小白笔记---------------------------------leetcode(48. Rotate Image )
- 小白笔记----------------leetcode(404. Sum of Left Leaves )
- 小白笔记----------------------------leetcode(237. Delete Node in a Linked List )
- 小白笔记-------------------------------leetcode(231. Power of Two)
- 小白笔记----------------leetcode 58. Length of Last Word
- 小白笔记-----------------------leetcode(8. String to Integer (atoi) )
- 小白笔记--------------leetcode(383. Ransom Note)
- 小白笔记-------------------leetcode(263. Ugly Number )
- 小白笔记-------------------------------leetcode(169. Majority Element)
- 小白笔记----------------------------------leetcode(22. Generate Parentheses )
- 小白笔记---------------------------------leetcode(70. Climbing Stairs )