困难——趣味题+字符串+综合

吐槽

真觉得sse设计得好蠢啊, 题的标签好甜蜜混乱. 改错题只有两道, 这字符串标签题中又有3道改错题. 趣味题就是恶心人的垃圾题.

小结

困难——趣味题 共4道, 都是移火柴的无聊题, 题干有些问题, 也不可能考.
困难——字符串 共20道左右. 非常简单的就没有写进来.
困难——综合 共3道, 不可能考.

1.

在这里插入图片描述

#include <stdio.h>
void  Squeeze(char *s, char c);
int main()
{
    char a[80], c, *s;
    s = a;
    scanf("%s",s); // 逆天重点: scanf %s 时不会读走空格 
    scanf(" %c",&c); // 精彩啊, %c前面要加个空格 
    Squeeze(s, c);
    printf("%s\n",s);
    return 0;
}
void  Squeeze(char *s, char c)
{
    int i,j;
    for (i=0, j=0; *(s+i) !='\0'; i++)
    {
        if (*(s+i) != c)
        { 
            *(s+j) = *(s+i);
            j++;
        }
    }
    *(s+j) = '\0';
}

2.

在这里插入图片描述

// 本来觉得浪费时间不想写的, 但是在网上看了两个人都写了100行, 一堆重复的switch ifelse语句. 遂自己写一遍.
#include <stdio.h>
char shuzi[12][12] = {"零", "一", "二", "三", "四", "五", "六", "七", "八", "九"};
char dadanwei[12][12] = {"", "万", "亿"}; // 大单位 
char xiaodanwei[12][12] = {"千", "百", "十", ""}; // 小单位 

void read(int n)
{
	int c[4], i;
	for (i = 3; i >= 0; i--) 
	{
		c[i] = n % 10;
		n /= 10;
	}
	for (i = 0; i < 4 && c[i] == 0; i ++) ; // 除去前导零 
	for (; i < 4; i ++)
	{		
		int j, flag = 0; //后导零处理  例如: 1008611一百零零万八千六百一十一 
		for(j = i + 1; j < 4; j ++) if(c[j]) flag = 1;
		if(c[i] != 0 || c[i] == 0 && flag) printf("%s", shuzi[c[i]]);
		if(c[i]) printf("%s", xiaodanwei[i]); 
	}
}
void Read(int n, int k)
{
	if (n == 0) return ;
	Read(n/10000, k+1);
	n %= 10000;
	read(n);	
	printf("%s", dadanwei[k]);
}

int main() 
{
	int n;
	scanf("%d", &n);
	Read(n, 0);
	return 0;
}

3.

// 一下是参考答案 这种题需要借鉴好的思路
#include <stdio.h>

int alphabetic(char c)
{	      	 
    if ((c >= 'a' && c <= 'z') || (c >= 'A' && c <= 'Z'))
    {	      	 
        return 1;
    }
    else
    {	      	 
        return 0;
    }
}	      	 

/* 寻找最长单词 */
int longest(char string[])
{	      	 
    int len = 0, i, length = 0, flag = 1, place, point;

    for (i = 0; i <= strlen(string); i++)
    {	      	 
        if (alphabetic(string[i]))
        {	      	 
            if (flag)
            {	      	 
                point = i;
                flag = 0;
            }
            else
            {	      	 
                len++;
            }
        }
        else
        {	      	 
            flag = 1;
            if (len > length)
            {	      	 
                length = len;
                place = point;
                len = 0;
            }
        }
    }
    return place;
}	      	 

int main()
{	      	 
    int i;
    char line[100];

    printf("输入一行文本:\n");
    gets(line);
    printf("\n最长的单词是:");
    for (i = longest(line); alphabetic(line[i]); i++)
    {	      	 
        printf("%c", line[i]);
    }
    printf("\n");

    return 0;
}	 

4

在这里插入图片描述

#include <stdio.h>
#include <string.h>
main( )
{
    int  cases, sum[10], i, max;
    char str[1000+10];
    scanf("%d", &cases);
    while (cases > 0)
    {
        scanf("%s", str);
        for (i = 0; i < 10; i++)
            sum[i] = 0;
        for (i = 0; i < strlen(str); i++)
            ++sum[str[i]-'0'];
        max = 0;
        for (i
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值