C语言习题~day38

1.添加逗号

对于一个较大的整数 N(1<=N<=2,000,000,000)

比如 980364535,我们常常需要一位一位数这个数字是几位数,但是如果在这 个数字每三位加一个逗号,它会变得更加易于朗读。

因此,这个数字加上逗号成如下的模样:980,364,535请写一个程序帮她完成这件事情

输入描述:

一行一个整数 N

输出描述:

一行一个字符串表示添加完逗号的结果

示例1 输入:980364535

输出: 980,364,535
思路:

可以从右往左每隔三位添加一个逗号。通过不断取整和取余数的操作来逐步处理数字。具体步骤如下:

  1. 将输入的整数转换为字符串。

  2. 从右往左遍历字符串,每三位一组,遇到一组就添加一个逗号,同时更新起始位置继续往左处理。

cpp 复制代码
 #include <stdio.h>
 
int main()
 {
    int n=0;
    scanf("%d",&n);
    int k=0;
    int i=0;
    char arr[14];
    while(n)
    {
        if(k!=0&&k%3==0)
        {
            arr[i++]=',';
        }
        arr[i++]=n%10+'0';
        n=n/10;
        k++;
    }
    for(i--;i>=0;i--)
    {
        printf("%c",arr[i]);
    }
    return 0;
 }

2.删除公共字符

输入两个字符串,从第一字符串中删除第二个字符串中所有的字符。例如,输入"They are students."和"aeiou",则删除之后的第一个字符串变成"Thy r stdnts."

输入描述:

每个测试输入包含2个字符串

输出描述:

输出删除后的字符串

输入:

复制代码
They are students. 
删除:aeiou

输出:

复制代码
Thy r stdnts.

**思路:**1. 遍历第二个字符串,将其中的每个字符存储到一个集合(可以用一个简单的标记数组来实现)中。

  1. 遍历第一个字符串,对于每个字符,如果它不在集合中,就将其输出。
cpp 复制代码
 #include <stdio.h>
 int BI(char ch,char arr2[])
 {
    int j=0;
    while(arr2[j])
    {
         if(ch==arr2[j])
         {
           return 0;
         }
         j++;
    }
    return 1;
 }
 int main()
 {
    char arr1[101];
    char arr2[101];
    gets(arr1);
    gets(arr2);
    int i=0;
     while(arr1[i])
     {
         if(BI(arr1[i],arr2)!=0)
         {
           printf("%c",arr1[i]);
         }
          i++;
     }
    return 0;
 }
相关推荐
爱编程— 的小李3 分钟前
有序序列合并(c语言)
c语言·算法
云卓SKYDROID5 分钟前
无人机反步滑膜控制算法!
算法·无人机·知识科普·云卓科技·反步滑膜控制算法
云卓科技5 分钟前
无人机之自动控制原理篇
科技·算法·目标检测·机器人·无人机
云卓科技7 分钟前
无人机之集群控制方法篇
科技·算法·无人机·交互·制造
混迹网络的权某7 分钟前
每天一道C语言精选编程题之求数字的每⼀位之和
c语言·开发语言·考研·算法·改行学it·1024程序员节
高雪峰9138 分钟前
C语言日记 2024年10月30日
数据结构·力扣
Curry_Math11 分钟前
LeetCode 热题 100之链表3
算法·leetcode·链表
hn小菜鸡3 小时前
LeetCode 2058.找出临界点之间的最小和最大距离
算法·leetcode·职场和发展
liuyang-neu3 小时前
力扣 简单 70.爬楼梯
java·算法·leetcode
IronmanJay3 小时前
【LeetCode每日一题】——862.和至少为 K 的最短子数组
数据结构·算法·leetcode·前缀和·双端队列·1024程序员节·和至少为 k 的最短子数组