求符合给定条件的整数集

题干:

给定不超过6的正整数A,考虑从A开始的连续4个数字,请输出所有由它们组成的无重复数字的3位数。

输入格式:

输入在一行中给出A

标题

输出格式:
输出满足条件的三位数,要求从小到大,每行6个整数。整数间以空格分隔,但行末不能有多余空格

输入样例:

2

输出样例:

234 235 243 245 253 254
324 325 342 345 352 354
423 425 432 435 452 453
523 524 532 534 542 543

*while循环

#include<stdio.h>
int main() {
	int i, j, k, A;       // i j k 代表 百 十 个位
	int cnt=0;           //cnt 计数
	scanf("%d", &A);
	i=A;
	while(i<=A+3) {      //i,j,k  <=A+3  表示 i,j,k只用 A 后连续的四个数字组成三位数
						//i=A,J=A.K=A,   每次让三位从开始往后查找,找一次各自+1
						//        例如:A=2, 查找从222~555
						//用if条件筛掉其中互相重复的数字, 当互相不重复才printf 
		j=A;
		while(j<=A+3) {
			k=A;
			while(k<=A+3) {
				if (i!=j) {            //百位十位不能重复
					if (i!=k) {       //百位个位不能重复
						if(j!=k) {    //十位个位不重复 
							cnt++ ;  //每找到一个符合条件的数就计数+1
							printf("%d%d%d", i,j,k);
							if (cnt==6) {
								printf("\n");           //当计数到6时换行
								cnt=0;             //换行后重新计数,计数器清零,再循环
							} else printf("  ");
						}
					}
				}
				k++; 
			}
			j++;
		}
		i++;
	}
	return 0;
}

for循环

#include<stdio.h>
int main()
{
    int i, j, k, A, count;
    scanf("%d", &A);
    for (i=A; i<=A+3; i++){
        count = 0;
        for (j=A; j<=A+3; j++){
            if (j!=i){
                for(k=A; k<=A+3; k++){
                    if (k!=i && k!=j){
                        count ++;
                        if (count==6) printf("%d", i*100+j*10+k);
                        else printf("%d ", i*100+j*10+k);
                    }
                }
            }
        }
        printf("\n");
    }
    return 0;
}


  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值