ACM题目————A simple problem
Description
Zty很痴迷数学问题.。一天,yifenfei出了个数学题想难倒他,让他回答1 / n。但Zty却回答不了^_^. 请大家编程帮助他.
Input
第一行整数T,表示测试组数。后面T行,每行一个整数 n (1<=|n|<=10^5).
Output
输出1/n. (是循环小数的,只输出第一个循环节).
Sample Input
4
2
3
7
168
Sample Output
0.5
0.3
0.142857
0.005952380
和我名字那么相近的题目,当然要AC了!
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 | //如果余数出现重复就表示有循环节 #include <stdio.h> #include <iostream> #include <algorithm> #include <iterator> #include <deque> #include <string> #include <string.h> #include <vector> #include <stack> #include <ctype.h> #include <queue> #include <math.h> #include <stdlib.h> #include <map> #include <set> #include <time.h> #include <bitset> #include <list> using namespace std; int f[100000]; int flag[100000]; int main() { int t,m,y,cnt,n,i; scanf ( "%d" ,&t); while (t--) { scanf ( "%d" ,&n); if (n<0) //如果是负数 { printf ( "-" ); //首先打印负号 n*=-1; //取反后当做正数处理 } if (n==1) { printf ( "1\n" ); continue ; } y=1; cnt=0; memset (flag,0, sizeof (flag)); //初始化为0 flag[1]=1; while (y) { y*=10; f[cnt++]=y/n; y%=n; if (flag[y]) //如果使用过,说明出现循环数节 break ; flag[y]=1; //记录余数是否使用过 } printf ( "0." ); for (i=0; i<cnt; i++) printf ( "%d" ,f[i]); printf ( "\n" ); } return 0; } |
低调做人,高调做事。
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 从 HTTP 原因短语缺失研究 HTTP/2 和 HTTP/3 的设计差异
· AI与.NET技术实操系列:向量存储与相似性搜索在 .NET 中的实现
· 基于Microsoft.Extensions.AI核心库实现RAG应用
· Linux系列:如何用heaptrack跟踪.NET程序的非托管内存泄露
· 开发者必知的日志记录最佳实践
· TypeScript + Deepseek 打造卜卦网站:技术与玄学的结合
· Manus的开源复刻OpenManus初探
· AI 智能体引爆开源社区「GitHub 热点速览」
· 从HTTP原因短语缺失研究HTTP/2和HTTP/3的设计差异
· 三行代码完成国际化适配,妙~啊~