求最小公倍数
data:image/s3,"s3://crabby-images/35a39/35a39f112ac5e6351c9d027b0400ef2f6b7eb738" alt=""
思路:假设两个数,5和7,那么最小至少也要7吧,所以先假定最小公倍数是两个数之间较大的,然后看7能不能同时整除5和7,不能就加1继续除
cpp
int GetLCM(int _num1, int _num2)
{
int max = _num1>_num2 ? _num1 : _num2;
while (1)
{
//证明能同时整除
if (!(max%_num1) && !(max%_num2)) return max;
else max++;
}
}
int main()
{
//输入两个正整数
int num1, num2;
scanf("%d %d", &num1, &num2);
printf("%d\n", GetLCM(num1, num2));
return 0;
}
上面的方法效率太低需要优化
思路:a*i % b 看看能不能整除,能就a*i是最小公倍数,不能就i++
cpp
int main()
{
//输入两个数
int a, b;
scanf("%d %d", &a, &b);
//判断
int i = 1;
while (a*i % b) i++;
printf("%d\n", a*i);
return 0;
}
倒置字符串
data:image/s3,"s3://crabby-images/bc801/bc801873e2762949eb082d6efee4fd57637d6ca7" alt=""
思路:1. scanf这个函数它读到空格它就不读了,所以我们要这样写scanf("%[^\n]s"),它的意思是往后读一直读到\n。
- 先把整个字符串倒置,再将每个单词倒置
cpp
void reverse(char* start, char* end)
{
char tmp;
while (start < end)
{
tmp = *start;
*start = *end;
*end = tmp;
start++;
end--;
}
}
int main() {
char arr[100];
scanf("%[^\n]s", arr);
int len = strlen(arr);
char* start = arr;
char* end = start + (len - 1);
reverse(start, end); //倒置整个数组
start = arr;
end = arr;
while (*end++)
{
while (*end != ' ' && *end != '\0')
{
end++;
}
reverse(start, end - 1);
start = end + 1;
}
printf("%s\n", arr);
return 0;
}
data:image/s3,"s3://crabby-images/78533/78533642cb9c9326cf1566e1ceaebf3a1096ad86" alt=""
data:image/s3,"s3://crabby-images/c946b/c946b0f11e1b265a7a4cfdcac990b35b93e9548f" alt=""
data:image/s3,"s3://crabby-images/80152/80152dace1b6a8025c331174f40a4a8dde8c6057" alt=""
data:image/s3,"s3://crabby-images/6c75c/6c75ca1e3f1e68392e244809ea49559916a17423" alt=""
data:image/s3,"s3://crabby-images/4dc7b/4dc7be36bb52ed7054fcaf552989f4a916f04f96" alt=""
data:image/s3,"s3://crabby-images/46296/462961abf5055c2bcb08534165b3f7a6c86e55eb" alt=""
data:image/s3,"s3://crabby-images/e2a19/e2a1917fd0ba6891088cf971e1c2e62b2f084547" alt=""
data:image/s3,"s3://crabby-images/6bee7/6bee73159e513f3ca013cb006495e0dcc1a840cc" alt=""
data:image/s3,"s3://crabby-images/be6b8/be6b894abcc1f51c885cb151c8c7f37889ade17a" alt=""
data:image/s3,"s3://crabby-images/76e99/76e99e971298a7f175a98b4a80f8805146e261ef" alt=""
data:image/s3,"s3://crabby-images/0ab9a/0ab9aebff14a40a3a07888853b626e62d9422ff7" alt=""
解析:3和2都是整数,所以3/2等于1
data:image/s3,"s3://crabby-images/1cc02/1cc026d2bdb8f7f4ca79a5620041e78e39cc6ba8" alt=""
data:image/s3,"s3://crabby-images/df49f/df49ff1aba9c7825507fa36797dfad4956025d87" alt=""
data:image/s3,"s3://crabby-images/8191d/8191dd59e64a73e6c8c54d7de7d127491c49b190" alt=""
data:image/s3,"s3://crabby-images/b876e/b876e9814a5dbbffddccdd6c47ec4899cd66c1a0" alt=""